sge.h 5.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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, write to the Free Software Foundation, Inc., *
  15. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
  16. * *
  17. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED *
  18. * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF *
  19. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. *
  20. * *
  21. * http://www.chelsio.com *
  22. * *
  23. * Copyright (c) 2003 - 2005 Chelsio Communications, Inc. *
  24. * All rights reserved. *
  25. * *
  26. * Maintainers: maintainers@chelsio.com *
  27. * *
  28. * Authors: Dimitrios Michailidis <dm@chelsio.com> *
  29. * Tina Yang <tainay@chelsio.com> *
  30. * Felix Marti <felix@chelsio.com> *
  31. * Scott Bardone <sbardone@chelsio.com> *
  32. * Kurt Ottaway <kottaway@chelsio.com> *
  33. * Frank DiMambro <frank@chelsio.com> *
  34. * *
  35. * History: *
  36. * *
  37. ****************************************************************************/
  38. #ifndef _CXGB_SGE_H_
  39. #define _CXGB_SGE_H_
  40. #include <linux/types.h>
  41. #include <linux/interrupt.h>
  42. #include <asm/byteorder.h>
  43. struct sge_intr_counts {
  44. unsigned int rx_drops; /* # of packets dropped due to no mem */
  45. unsigned int pure_rsps; /* # of non-payload responses */
  46. unsigned int unhandled_irqs; /* # of unhandled interrupts */
  47. unsigned int respQ_empty; /* # times respQ empty */
  48. unsigned int respQ_overflow; /* # respQ overflow (fatal) */
  49. unsigned int freelistQ_empty; /* # times freelist empty */
  50. unsigned int pkt_too_big; /* packet too large (fatal) */
  51. unsigned int pkt_mismatch;
  52. unsigned int cmdQ_full[3]; /* not HW IRQ, host cmdQ[] full */
  53. unsigned int cmdQ_restarted[3];/* # of times cmdQ X was restarted */
  54. };
  55. struct sge_port_stats {
  56. u64 rx_cso_good; /* # of successful RX csum offloads */
  57. u64 tx_cso; /* # of TX checksum offloads */
  58. u64 tx_tso; /* # of TSO requests */
  59. u64 vlan_xtract; /* # of VLAN tag extractions */
  60. u64 vlan_insert; /* # of VLAN tag insertions */
  61. u64 tx_need_hdrroom; /* # of TX skbs in need of more header room */
  62. };
  63. struct sk_buff;
  64. struct net_device;
  65. struct adapter;
  66. struct sge_params;
  67. struct sge;
  68. struct sge *t1_sge_create(struct adapter *, struct sge_params *);
  69. int t1_sge_configure(struct sge *, struct sge_params *);
  70. int t1_sge_set_coalesce_params(struct sge *, struct sge_params *);
  71. void t1_sge_destroy(struct sge *);
  72. irqreturn_t t1_interrupt(int irq, void *cookie);
  73. int t1_poll(struct napi_struct *, int);
  74. netdev_tx_t t1_start_xmit(struct sk_buff *skb, struct net_device *dev);
  75. void t1_vlan_mode(struct adapter *adapter, netdev_features_t features);
  76. void t1_sge_start(struct sge *);
  77. void t1_sge_stop(struct sge *);
  78. int t1_sge_intr_error_handler(struct sge *);
  79. void t1_sge_intr_enable(struct sge *);
  80. void t1_sge_intr_disable(struct sge *);
  81. void t1_sge_intr_clear(struct sge *);
  82. const struct sge_intr_counts *t1_sge_get_intr_counts(const struct sge *sge);
  83. void t1_sge_get_port_stats(const struct sge *sge, int port, struct sge_port_stats *);
  84. unsigned int t1_sched_update_parms(struct sge *, unsigned int, unsigned int,
  85. unsigned int);
  86. #endif /* _CXGB_SGE_H_ */