Hardware software co design for network processor architecture through integration of scheduling algorithm for switching fabric using VLSI