fw_common.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2009-2014 Realtek Corporation.
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of version 2 of the GNU General Public License as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful, but WITHOUT
  10. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  12. * more details.
  13. *
  14. * The full GNU General Public License is included in this distribution in the
  15. * file called LICENSE.
  16. *
  17. * Contact Information:
  18. * wlanfae <wlanfae@realtek.com>
  19. * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
  20. * Hsinchu 300, Taiwan.
  21. *
  22. * Larry Finger <Larry.Finger@lwfinger.net>
  23. *
  24. *****************************************************************************/
  25. #ifndef __FW_COMMON_H__
  26. #define __FW_COMMON_H__
  27. #define REG_SYS_FUNC_EN 0x0002
  28. #define REG_MCUFWDL 0x0080
  29. #define FW_8192C_START_ADDRESS 0x1000
  30. #define FW_8192C_PAGE_SIZE 4096
  31. #define FW_8723A_POLLING_TIMEOUT_COUNT 1000
  32. #define FW_8723B_POLLING_TIMEOUT_COUNT 6000
  33. #define FW_8192C_POLLING_DELAY 5
  34. #define MCUFWDL_RDY BIT(1)
  35. #define FWDL_CHKSUM_RPT BIT(2)
  36. #define WINTINI_RDY BIT(6)
  37. #define REG_RSV_CTRL 0x001C
  38. #define REG_HMETFR 0x01CC
  39. enum version_8723e {
  40. VERSION_TEST_UMC_CHIP_8723 = 0x0081,
  41. VERSION_NORMAL_UMC_CHIP_8723_1T1R_A_CUT = 0x0089,
  42. VERSION_NORMAL_UMC_CHIP_8723_1T1R_B_CUT = 0x1089,
  43. VERSION_TEST_CHIP_1T1R_8723B = 0x0106,
  44. VERSION_NORMAL_SMIC_CHIP_1T1R_8723B = 0x010E,
  45. VERSION_UNKNOWN = 0xFF,
  46. };
  47. enum rtl8723be_cmd {
  48. H2C_8723BE_RSVDPAGE = 0,
  49. H2C_8723BE_JOINBSSRPT = 1,
  50. H2C_8723BE_SCAN = 2,
  51. H2C_8723BE_KEEP_ALIVE_CTRL = 3,
  52. H2C_8723BE_DISCONNECT_DECISION = 4,
  53. H2C_8723BE_INIT_OFFLOAD = 6,
  54. H2C_8723BE_AP_OFFLOAD = 8,
  55. H2C_8723BE_BCN_RSVDPAGE = 9,
  56. H2C_8723BE_PROBERSP_RSVDPAGE = 10,
  57. H2C_8723BE_SETPWRMODE = 0x20,
  58. H2C_8723BE_PS_TUNING_PARA = 0x21,
  59. H2C_8723BE_PS_TUNING_PARA2 = 0x22,
  60. H2C_8723BE_PS_LPS_PARA = 0x23,
  61. H2C_8723BE_P2P_PS_OFFLOAD = 0x24,
  62. H2C_8723BE_WO_WLAN = 0x80,
  63. H2C_8723BE_REMOTE_WAKE_CTRL = 0x81,
  64. H2C_8723BE_AOAC_GLOBAL_INFO = 0x82,
  65. H2C_8723BE_AOAC_RSVDPAGE = 0x83,
  66. H2C_8723BE_RSSI_REPORT = 0x42,
  67. H2C_8723BE_RA_MASK = 0x40,
  68. H2C_8723BE_SELECTIVE_SUSPEND_ROF_CMD,
  69. H2C_8723BE_P2P_PS_MODE,
  70. H2C_8723BE_PSD_RESULT,
  71. /*Not defined CTW CMD for P2P yet*/
  72. H2C_8723BE_P2P_PS_CTW_CMD,
  73. MAX_8723BE_H2CCMD
  74. };
  75. void rtl8723ae_firmware_selfreset(struct ieee80211_hw *hw);
  76. void rtl8723be_firmware_selfreset(struct ieee80211_hw *hw);
  77. void rtl8723_enable_fw_download(struct ieee80211_hw *hw, bool enable);
  78. void rtl8723_fw_block_write(struct ieee80211_hw *hw,
  79. const u8 *buffer, u32 size);
  80. void rtl8723_fw_page_write(struct ieee80211_hw *hw,
  81. u32 page, const u8 *buffer, u32 size);
  82. void rtl8723_write_fw(struct ieee80211_hw *hw,
  83. enum version_8723e version,
  84. u8 *buffer, u32 size, u8 max_page);
  85. int rtl8723_fw_free_to_go(struct ieee80211_hw *hw, bool is_8723be, int count);
  86. int rtl8723_download_fw(struct ieee80211_hw *hw, bool is_8723be, int count);
  87. bool rtl8723_cmd_send_packet(struct ieee80211_hw *hw,
  88. struct sk_buff *skb);
  89. void rtl8723_fill_dummy(u8 *pfwbuf, u32 *pfwlen);
  90. #endif