sge.h 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*****************************************************************************
  2. * *
  3. * File: sge.h *
  4. * $Revision: 1.11 $ *
  5. * $Date: 2005/06/21 22:10:55 $ *
  6. * Description: *
  7. * part of the Chelsio 10Gb Ethernet Driver. *
  8. * *
  9. * This program is free software; you can redistribute it and/or modify *
  10. * it under the terms of the GNU General Public License, version 2, as *
  11. * published by the Free Software Foundation. *
  12. * *
  13. * You should have received a copy of the GNU General Public License along *
  14. * with this program; if not, see <http://www.gnu.org/licenses/>. *
  15. * *
  16. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED *
  17. * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF *
  18. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. *
  19. * *
  20. * http://www.chelsio.com *
  21. * *
  22. * Copyright (c) 2003 - 2005 Chelsio Communications, Inc. *
  23. * All rights reserved. *
  24. * *
  25. * Maintainers: maintainers@chelsio.com *
  26. * *
  27. * Authors: Dimitrios Michailidis <dm@chelsio.com> *
  28. * Tina Yang <tainay@chelsio.com> *
  29. * Felix Marti <felix@chelsio.com> *
  30. * Scott Bardone <sbardone@chelsio.com> *
  31. * Kurt Ottaway <kottaway@chelsio.com> *
  32. * Frank DiMambro <frank@chelsio.com> *
  33. * *
  34. * History: *
  35. * *
  36. ****************************************************************************/
  37. #ifndef _CXGB_SGE_H_
  38. #define _CXGB_SGE_H_
  39. #include <linux/types.h>
  40. #include <linux/interrupt.h>
  41. #include <asm/byteorder.h>
  42. struct sge_intr_counts {
  43. unsigned int rx_drops; /* # of packets dropped due to no mem */
  44. unsigned int pure_rsps; /* # of non-payload responses */
  45. unsigned int unhandled_irqs; /* # of unhandled interrupts */
  46. unsigned int respQ_empty; /* # times respQ empty */
  47. unsigned int respQ_overflow; /* # respQ overflow (fatal) */
  48. unsigned int freelistQ_empty; /* # times freelist empty */
  49. unsigned int pkt_too_big; /* packet too large (fatal) */
  50. unsigned int pkt_mismatch;
  51. unsigned int cmdQ_full[3]; /* not HW IRQ, host cmdQ[] full */
  52. unsigned int cmdQ_restarted[3];/* # of times cmdQ X was restarted */
  53. };
  54. struct sge_port_stats {
  55. u64 rx_cso_good; /* # of successful RX csum offloads */
  56. u64 tx_cso; /* # of TX checksum offloads */
  57. u64 tx_tso; /* # of TSO requests */
  58. u64 vlan_xtract; /* # of VLAN tag extractions */
  59. u64 vlan_insert; /* # of VLAN tag insertions */
  60. u64 tx_need_hdrroom; /* # of TX skbs in need of more header room */
  61. };
  62. struct sk_buff;
  63. struct net_device;
  64. struct adapter;
  65. struct sge_params;
  66. struct sge;
  67. struct sge *t1_sge_create(struct adapter *, struct sge_params *);
  68. int t1_sge_configure(struct sge *, struct sge_params *);
  69. int t1_sge_set_coalesce_params(struct sge *, struct sge_params *);
  70. void t1_sge_destroy(struct sge *);
  71. irqreturn_t t1_interrupt(int irq, void *cookie);
  72. int t1_poll(struct napi_struct *, int);
  73. netdev_tx_t t1_start_xmit(struct sk_buff *skb, struct net_device *dev);
  74. void t1_vlan_mode(struct adapter *adapter, netdev_features_t features);
  75. void t1_sge_start(struct sge *);
  76. void t1_sge_stop(struct sge *);
  77. int t1_sge_intr_error_handler(struct sge *);
  78. void t1_sge_intr_enable(struct sge *);
  79. void t1_sge_intr_disable(struct sge *);
  80. void t1_sge_intr_clear(struct sge *);
  81. const struct sge_intr_counts *t1_sge_get_intr_counts(const struct sge *sge);
  82. void t1_sge_get_port_stats(const struct sge *sge, int port, struct sge_port_stats *);
  83. unsigned int t1_sched_update_parms(struct sge *, unsigned int, unsigned int,
  84. unsigned int);
  85. #endif /* _CXGB_SGE_H_ */