qlcnic_83xx_vnic.c 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. /*
  2. * QLogic qlcnic NIC Driver
  3. * Copyright (c) 2009-2013 QLogic Corporation
  4. *
  5. * See LICENSE.qlcnic for copyright and licensing details.
  6. */
  7. #include "qlcnic.h"
  8. #include "qlcnic_hw.h"
  9. int qlcnic_83xx_enable_vnic_mode(struct qlcnic_adapter *adapter, int lock)
  10. {
  11. if (lock) {
  12. if (qlcnic_83xx_lock_driver(adapter))
  13. return -EBUSY;
  14. }
  15. QLCWRX(adapter->ahw, QLC_83XX_VNIC_STATE, QLCNIC_DEV_NPAR_OPER);
  16. if (lock)
  17. qlcnic_83xx_unlock_driver(adapter);
  18. return 0;
  19. }
  20. int qlcnic_83xx_disable_vnic_mode(struct qlcnic_adapter *adapter, int lock)
  21. {
  22. struct qlcnic_hardware_context *ahw = adapter->ahw;
  23. if (lock) {
  24. if (qlcnic_83xx_lock_driver(adapter))
  25. return -EBUSY;
  26. }
  27. QLCWRX(adapter->ahw, QLC_83XX_VNIC_STATE, QLCNIC_DEV_NPAR_NON_OPER);
  28. ahw->idc.vnic_state = QLCNIC_DEV_NPAR_NON_OPER;
  29. if (lock)
  30. qlcnic_83xx_unlock_driver(adapter);
  31. return 0;
  32. }
  33. static int qlcnic_83xx_set_vnic_opmode(struct qlcnic_adapter *adapter)
  34. {
  35. u8 id;
  36. int i, ret = -EBUSY;
  37. u32 data = QLCNIC_MGMT_FUNC;
  38. struct qlcnic_hardware_context *ahw = adapter->ahw;
  39. if (qlcnic_83xx_lock_driver(adapter))
  40. return ret;
  41. if (qlcnic_config_npars) {
  42. for (i = 0; i < ahw->act_pci_func; i++) {
  43. id = adapter->npars[i].pci_func;
  44. if (id == ahw->pci_func)
  45. continue;
  46. data |= qlcnic_config_npars &
  47. QLC_83XX_SET_FUNC_OPMODE(0x3, id);
  48. }
  49. } else {
  50. data = QLCRDX(adapter->ahw, QLC_83XX_DRV_OP_MODE);
  51. data = (data & ~QLC_83XX_SET_FUNC_OPMODE(0x3, ahw->pci_func)) |
  52. QLC_83XX_SET_FUNC_OPMODE(QLCNIC_MGMT_FUNC,
  53. ahw->pci_func);
  54. }
  55. QLCWRX(adapter->ahw, QLC_83XX_DRV_OP_MODE, data);
  56. qlcnic_83xx_unlock_driver(adapter);
  57. return 0;
  58. }
  59. static void
  60. qlcnic_83xx_config_vnic_buff_descriptors(struct qlcnic_adapter *adapter)
  61. {
  62. struct qlcnic_hardware_context *ahw = adapter->ahw;
  63. if (ahw->port_type == QLCNIC_XGBE) {
  64. adapter->num_rxd = DEFAULT_RCV_DESCRIPTORS_VF;
  65. adapter->max_rxd = MAX_RCV_DESCRIPTORS_VF;
  66. adapter->num_jumbo_rxd = MAX_JUMBO_RCV_DESCRIPTORS_10G;
  67. adapter->max_jumbo_rxd = MAX_JUMBO_RCV_DESCRIPTORS_10G;
  68. } else if (ahw->port_type == QLCNIC_GBE) {
  69. adapter->num_rxd = DEFAULT_RCV_DESCRIPTORS_1G;
  70. adapter->num_jumbo_rxd = MAX_JUMBO_RCV_DESCRIPTORS_1G;
  71. adapter->max_jumbo_rxd = MAX_JUMBO_RCV_DESCRIPTORS_1G;
  72. adapter->max_rxd = MAX_RCV_DESCRIPTORS_1G;
  73. }
  74. adapter->num_txd = MAX_CMD_DESCRIPTORS;
  75. adapter->max_rds_rings = MAX_RDS_RINGS;
  76. }
  77. /**
  78. * qlcnic_83xx_init_mgmt_vnic
  79. *
  80. * @adapter: adapter structure
  81. * Management virtual NIC sets the operational mode of other vNIC's and
  82. * configures embedded switch (ESWITCH).
  83. * Returns: Success(0) or error code.
  84. *
  85. **/
  86. static int qlcnic_83xx_init_mgmt_vnic(struct qlcnic_adapter *adapter)
  87. {
  88. int err = -EIO;
  89. qlcnic_83xx_get_minidump_template(adapter);
  90. if (!(adapter->flags & QLCNIC_ADAPTER_INITIALIZED)) {
  91. if (qlcnic_init_pci_info(adapter))
  92. return err;
  93. if (qlcnic_83xx_set_vnic_opmode(adapter))
  94. return err;
  95. if (qlcnic_set_default_offload_settings(adapter))
  96. return err;
  97. } else {
  98. if (qlcnic_reset_npar_config(adapter))
  99. return err;
  100. }
  101. if (qlcnic_83xx_get_port_info(adapter))
  102. return err;
  103. qlcnic_83xx_config_vnic_buff_descriptors(adapter);
  104. adapter->ahw->msix_supported = !!qlcnic_use_msi_x;
  105. adapter->flags |= QLCNIC_ADAPTER_INITIALIZED;
  106. qlcnic_83xx_enable_vnic_mode(adapter, 1);
  107. dev_info(&adapter->pdev->dev, "HAL Version: %d, Management function\n",
  108. adapter->ahw->fw_hal_version);
  109. return 0;
  110. }
  111. static int qlcnic_83xx_init_privileged_vnic(struct qlcnic_adapter *adapter)
  112. {
  113. int err = -EIO;
  114. qlcnic_83xx_get_minidump_template(adapter);
  115. if (qlcnic_83xx_get_port_info(adapter))
  116. return err;
  117. qlcnic_83xx_config_vnic_buff_descriptors(adapter);
  118. adapter->ahw->msix_supported = !!qlcnic_use_msi_x;
  119. adapter->flags |= QLCNIC_ADAPTER_INITIALIZED;
  120. dev_info(&adapter->pdev->dev,
  121. "HAL Version: %d, Privileged function\n",
  122. adapter->ahw->fw_hal_version);
  123. return 0;
  124. }
  125. static int qlcnic_83xx_init_non_privileged_vnic(struct qlcnic_adapter *adapter)
  126. {
  127. int err = -EIO;
  128. qlcnic_83xx_get_fw_version(adapter);
  129. if (qlcnic_set_eswitch_port_config(adapter))
  130. return err;
  131. if (qlcnic_83xx_get_port_info(adapter))
  132. return err;
  133. qlcnic_83xx_config_vnic_buff_descriptors(adapter);
  134. adapter->ahw->msix_supported = !!qlcnic_use_msi_x;
  135. adapter->flags |= QLCNIC_ADAPTER_INITIALIZED;
  136. dev_info(&adapter->pdev->dev, "HAL Version: %d, Virtual function\n",
  137. adapter->ahw->fw_hal_version);
  138. return 0;
  139. }
  140. /**
  141. * qlcnic_83xx_vnic_opmode
  142. *
  143. * @adapter: adapter structure
  144. * Identify virtual NIC operational modes.
  145. *
  146. * Returns: Success(0) or error code.
  147. *
  148. **/
  149. int qlcnic_83xx_config_vnic_opmode(struct qlcnic_adapter *adapter)
  150. {
  151. u32 op_mode, priv_level;
  152. struct qlcnic_hardware_context *ahw = adapter->ahw;
  153. struct qlcnic_nic_template *nic_ops = adapter->nic_ops;
  154. qlcnic_get_func_no(adapter);
  155. op_mode = QLCRDX(adapter->ahw, QLC_83XX_DRV_OP_MODE);
  156. if (op_mode == QLC_83XX_DEFAULT_OPMODE)
  157. priv_level = QLCNIC_MGMT_FUNC;
  158. else
  159. priv_level = QLC_83XX_GET_FUNC_PRIVILEGE(op_mode,
  160. ahw->pci_func);
  161. if (priv_level == QLCNIC_NON_PRIV_FUNC) {
  162. ahw->op_mode = QLCNIC_NON_PRIV_FUNC;
  163. ahw->idc.state_entry = qlcnic_83xx_idc_ready_state_entry;
  164. nic_ops->init_driver = qlcnic_83xx_init_non_privileged_vnic;
  165. } else if (priv_level == QLCNIC_PRIV_FUNC) {
  166. ahw->op_mode = QLCNIC_PRIV_FUNC;
  167. ahw->idc.state_entry = qlcnic_83xx_idc_vnic_pf_entry;
  168. nic_ops->init_driver = qlcnic_83xx_init_privileged_vnic;
  169. } else if (priv_level == QLCNIC_MGMT_FUNC) {
  170. ahw->op_mode = QLCNIC_MGMT_FUNC;
  171. ahw->idc.state_entry = qlcnic_83xx_idc_ready_state_entry;
  172. nic_ops->init_driver = qlcnic_83xx_init_mgmt_vnic;
  173. } else {
  174. return -EIO;
  175. }
  176. if (ahw->capabilities & BIT_23)
  177. adapter->flags |= QLCNIC_ESWITCH_ENABLED;
  178. else
  179. adapter->flags &= ~QLCNIC_ESWITCH_ENABLED;
  180. adapter->ahw->idc.vnic_state = QLCNIC_DEV_NPAR_NON_OPER;
  181. adapter->ahw->idc.vnic_wait_limit = QLCNIC_DEV_NPAR_OPER_TIMEO;
  182. return 0;
  183. }