bnx: Implement multiple RX/TX rings and MSI-X support for 5718/57785
BCM5718 and BCM57785 families support 4 RX rings and 5 MSI-X vectors.
Additionally BCM5719/BCM5720 support 4 TX rings, while other chips in
these two families only support 1 TX ring. Each MSI-X vector has its
own interrupt moderation parameters.
Hardware supplied RSS hash and packet type are not utilized yet; they
will be supported in the upcoming commits.
This commit also fixes some RX standard ring refilling races introduced
in:
841cdf08263117c54b0a800440c7630b6913c21e
RX standard ring refilling scheduling may enjoy futher optimization.