rsi_91x_hal.c 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990
  1. /**
  2. * Copyright (c) 2014 Redpine Signals Inc.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  11. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  14. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #include <linux/firmware.h>
  17. #include <net/bluetooth/bluetooth.h>
  18. #include "rsi_mgmt.h"
  19. #include "rsi_hal.h"
  20. #include "rsi_sdio.h"
  21. #include "rsi_common.h"
  22. /* FLASH Firmware */
  23. static struct ta_metadata metadata_flash_content[] = {
  24. {"flash_content", 0x00010000},
  25. {"rsi/rs9113_wlan_qspi.rps", 0x00010000},
  26. {"rsi/rs9113_wlan_bt_dual_mode.rps", 0x00010000},
  27. };
  28. int rsi_send_pkt_to_bus(struct rsi_common *common, struct sk_buff *skb)
  29. {
  30. struct rsi_hw *adapter = common->priv;
  31. int status;
  32. if (common->coex_mode > 1)
  33. mutex_lock(&common->tx_bus_mutex);
  34. status = adapter->host_intf_ops->write_pkt(common->priv,
  35. skb->data, skb->len);
  36. if (common->coex_mode > 1)
  37. mutex_unlock(&common->tx_bus_mutex);
  38. return status;
  39. }
  40. static int rsi_prepare_mgmt_desc(struct rsi_common *common, struct sk_buff *skb)
  41. {
  42. struct rsi_hw *adapter = common->priv;
  43. struct ieee80211_hdr *wh = NULL;
  44. struct ieee80211_tx_info *info;
  45. struct ieee80211_conf *conf = &adapter->hw->conf;
  46. struct ieee80211_vif *vif;
  47. struct rsi_mgmt_desc *mgmt_desc;
  48. struct skb_info *tx_params;
  49. struct ieee80211_bss_conf *bss = NULL;
  50. struct xtended_desc *xtend_desc = NULL;
  51. u8 header_size;
  52. u32 dword_align_bytes = 0;
  53. if (skb->len > MAX_MGMT_PKT_SIZE) {
  54. rsi_dbg(INFO_ZONE, "%s: Dropping mgmt pkt > 512\n", __func__);
  55. return -EINVAL;
  56. }
  57. info = IEEE80211_SKB_CB(skb);
  58. tx_params = (struct skb_info *)info->driver_data;
  59. vif = tx_params->vif;
  60. /* Update header size */
  61. header_size = FRAME_DESC_SZ + sizeof(struct xtended_desc);
  62. if (header_size > skb_headroom(skb)) {
  63. rsi_dbg(ERR_ZONE,
  64. "%s: Failed to add extended descriptor\n",
  65. __func__);
  66. return -ENOSPC;
  67. }
  68. skb_push(skb, header_size);
  69. dword_align_bytes = ((unsigned long)skb->data & 0x3f);
  70. if (dword_align_bytes > skb_headroom(skb)) {
  71. rsi_dbg(ERR_ZONE,
  72. "%s: Failed to add dword align\n", __func__);
  73. return -ENOSPC;
  74. }
  75. skb_push(skb, dword_align_bytes);
  76. header_size += dword_align_bytes;
  77. tx_params->internal_hdr_size = header_size;
  78. memset(&skb->data[0], 0, header_size);
  79. bss = &vif->bss_conf;
  80. wh = (struct ieee80211_hdr *)&skb->data[header_size];
  81. mgmt_desc = (struct rsi_mgmt_desc *)skb->data;
  82. xtend_desc = (struct xtended_desc *)&skb->data[FRAME_DESC_SZ];
  83. rsi_set_len_qno(&mgmt_desc->len_qno, (skb->len - FRAME_DESC_SZ),
  84. RSI_WIFI_MGMT_Q);
  85. mgmt_desc->frame_type = TX_DOT11_MGMT;
  86. mgmt_desc->header_len = MIN_802_11_HDR_LEN;
  87. mgmt_desc->xtend_desc_size = header_size - FRAME_DESC_SZ;
  88. mgmt_desc->frame_info |= cpu_to_le16(RATE_INFO_ENABLE);
  89. if (is_broadcast_ether_addr(wh->addr1))
  90. mgmt_desc->frame_info |= cpu_to_le16(RSI_BROADCAST_PKT);
  91. mgmt_desc->seq_ctrl =
  92. cpu_to_le16(IEEE80211_SEQ_TO_SN(le16_to_cpu(wh->seq_ctrl)));
  93. if ((common->band == NL80211_BAND_2GHZ) && !common->p2p_enabled)
  94. mgmt_desc->rate_info = cpu_to_le16(RSI_RATE_1);
  95. else
  96. mgmt_desc->rate_info = cpu_to_le16(RSI_RATE_6);
  97. if (conf_is_ht40(conf))
  98. mgmt_desc->bbp_info = cpu_to_le16(FULL40M_ENABLE);
  99. if (ieee80211_is_probe_req(wh->frame_control)) {
  100. if (!bss->assoc) {
  101. rsi_dbg(INFO_ZONE,
  102. "%s: blocking mgmt queue\n", __func__);
  103. mgmt_desc->misc_flags = RSI_DESC_REQUIRE_CFM_TO_HOST;
  104. xtend_desc->confirm_frame_type = PROBEREQ_CONFIRM;
  105. common->mgmt_q_block = true;
  106. rsi_dbg(INFO_ZONE, "Mgmt queue blocked\n");
  107. }
  108. }
  109. if (ieee80211_is_probe_resp(wh->frame_control)) {
  110. mgmt_desc->misc_flags |= (RSI_ADD_DELTA_TSF_VAP_ID |
  111. RSI_FETCH_RETRY_CNT_FRM_HST);
  112. #define PROBE_RESP_RETRY_CNT 3
  113. xtend_desc->retry_cnt = PROBE_RESP_RETRY_CNT;
  114. }
  115. if (((vif->type == NL80211_IFTYPE_AP) ||
  116. (vif->type == NL80211_IFTYPE_P2P_GO)) &&
  117. (ieee80211_is_action(wh->frame_control))) {
  118. struct rsi_sta *rsta = rsi_find_sta(common, wh->addr1);
  119. if (rsta)
  120. mgmt_desc->sta_id = tx_params->sta_id;
  121. else
  122. return -EINVAL;
  123. }
  124. mgmt_desc->rate_info |=
  125. cpu_to_le16((tx_params->vap_id << RSI_DESC_VAP_ID_OFST) &
  126. RSI_DESC_VAP_ID_MASK);
  127. return 0;
  128. }
  129. /* This function prepares descriptor for given data packet */
  130. static int rsi_prepare_data_desc(struct rsi_common *common, struct sk_buff *skb)
  131. {
  132. struct rsi_hw *adapter = common->priv;
  133. struct ieee80211_vif *vif;
  134. struct ieee80211_hdr *wh = NULL;
  135. struct ieee80211_tx_info *info;
  136. struct skb_info *tx_params;
  137. struct ieee80211_bss_conf *bss;
  138. struct rsi_data_desc *data_desc;
  139. struct xtended_desc *xtend_desc;
  140. u8 ieee80211_size = MIN_802_11_HDR_LEN;
  141. u8 header_size;
  142. u8 vap_id = 0;
  143. u8 dword_align_bytes;
  144. u16 seq_num;
  145. info = IEEE80211_SKB_CB(skb);
  146. vif = info->control.vif;
  147. bss = &vif->bss_conf;
  148. tx_params = (struct skb_info *)info->driver_data;
  149. header_size = FRAME_DESC_SZ + sizeof(struct xtended_desc);
  150. if (header_size > skb_headroom(skb)) {
  151. rsi_dbg(ERR_ZONE, "%s: Unable to send pkt\n", __func__);
  152. return -ENOSPC;
  153. }
  154. skb_push(skb, header_size);
  155. dword_align_bytes = ((unsigned long)skb->data & 0x3f);
  156. if (header_size > skb_headroom(skb)) {
  157. rsi_dbg(ERR_ZONE, "%s: Not enough headroom\n", __func__);
  158. return -ENOSPC;
  159. }
  160. skb_push(skb, dword_align_bytes);
  161. header_size += dword_align_bytes;
  162. tx_params->internal_hdr_size = header_size;
  163. data_desc = (struct rsi_data_desc *)skb->data;
  164. memset(data_desc, 0, header_size);
  165. xtend_desc = (struct xtended_desc *)&skb->data[FRAME_DESC_SZ];
  166. wh = (struct ieee80211_hdr *)&skb->data[header_size];
  167. seq_num = IEEE80211_SEQ_TO_SN(le16_to_cpu(wh->seq_ctrl));
  168. data_desc->xtend_desc_size = header_size - FRAME_DESC_SZ;
  169. if (ieee80211_is_data_qos(wh->frame_control)) {
  170. ieee80211_size += 2;
  171. data_desc->mac_flags |= cpu_to_le16(RSI_QOS_ENABLE);
  172. }
  173. if (((vif->type == NL80211_IFTYPE_STATION) ||
  174. (vif->type == NL80211_IFTYPE_P2P_CLIENT)) &&
  175. (adapter->ps_state == PS_ENABLED))
  176. wh->frame_control |= cpu_to_le16(RSI_SET_PS_ENABLE);
  177. if ((!(info->flags & IEEE80211_TX_INTFL_DONT_ENCRYPT)) &&
  178. (common->secinfo.security_enable)) {
  179. if (rsi_is_cipher_wep(common))
  180. ieee80211_size += 4;
  181. else
  182. ieee80211_size += 8;
  183. data_desc->mac_flags |= cpu_to_le16(RSI_ENCRYPT_PKT);
  184. }
  185. rsi_set_len_qno(&data_desc->len_qno, (skb->len - FRAME_DESC_SZ),
  186. RSI_WIFI_DATA_Q);
  187. data_desc->header_len = ieee80211_size;
  188. if (common->min_rate != RSI_RATE_AUTO) {
  189. /* Send fixed rate */
  190. data_desc->frame_info = cpu_to_le16(RATE_INFO_ENABLE);
  191. data_desc->rate_info = cpu_to_le16(common->min_rate);
  192. if (conf_is_ht40(&common->priv->hw->conf))
  193. data_desc->bbp_info = cpu_to_le16(FULL40M_ENABLE);
  194. if ((common->vif_info[0].sgi) && (common->min_rate & 0x100)) {
  195. /* Only MCS rates */
  196. data_desc->rate_info |=
  197. cpu_to_le16(ENABLE_SHORTGI_RATE);
  198. }
  199. }
  200. if (skb->protocol == cpu_to_be16(ETH_P_PAE)) {
  201. rsi_dbg(INFO_ZONE, "*** Tx EAPOL ***\n");
  202. data_desc->frame_info = cpu_to_le16(RATE_INFO_ENABLE);
  203. if (common->band == NL80211_BAND_5GHZ)
  204. data_desc->rate_info = cpu_to_le16(RSI_RATE_6);
  205. else
  206. data_desc->rate_info = cpu_to_le16(RSI_RATE_1);
  207. data_desc->mac_flags |= cpu_to_le16(RSI_REKEY_PURPOSE);
  208. data_desc->misc_flags |= RSI_FETCH_RETRY_CNT_FRM_HST;
  209. #define EAPOL_RETRY_CNT 15
  210. xtend_desc->retry_cnt = EAPOL_RETRY_CNT;
  211. }
  212. data_desc->mac_flags = cpu_to_le16(seq_num & 0xfff);
  213. data_desc->qid_tid = ((skb->priority & 0xf) |
  214. ((tx_params->tid & 0xf) << 4));
  215. data_desc->sta_id = tx_params->sta_id;
  216. if ((is_broadcast_ether_addr(wh->addr1)) ||
  217. (is_multicast_ether_addr(wh->addr1))) {
  218. data_desc->frame_info = cpu_to_le16(RATE_INFO_ENABLE);
  219. data_desc->frame_info |= cpu_to_le16(RSI_BROADCAST_PKT);
  220. data_desc->sta_id = vap_id;
  221. if ((vif->type == NL80211_IFTYPE_AP) ||
  222. (vif->type == NL80211_IFTYPE_P2P_GO)) {
  223. if (common->band == NL80211_BAND_5GHZ)
  224. data_desc->rate_info = cpu_to_le16(RSI_RATE_6);
  225. else
  226. data_desc->rate_info = cpu_to_le16(RSI_RATE_1);
  227. }
  228. }
  229. if (((vif->type == NL80211_IFTYPE_AP) ||
  230. (vif->type == NL80211_IFTYPE_P2P_GO)) &&
  231. (ieee80211_has_moredata(wh->frame_control)))
  232. data_desc->frame_info |= cpu_to_le16(MORE_DATA_PRESENT);
  233. data_desc->rate_info |=
  234. cpu_to_le16((tx_params->vap_id << RSI_DESC_VAP_ID_OFST) &
  235. RSI_DESC_VAP_ID_MASK);
  236. return 0;
  237. }
  238. /* This function sends received data packet from driver to device */
  239. int rsi_send_data_pkt(struct rsi_common *common, struct sk_buff *skb)
  240. {
  241. struct rsi_hw *adapter = common->priv;
  242. struct ieee80211_vif *vif;
  243. struct ieee80211_tx_info *info;
  244. struct ieee80211_bss_conf *bss;
  245. int status = -EINVAL;
  246. if (!skb)
  247. return 0;
  248. if (common->iface_down)
  249. goto err;
  250. info = IEEE80211_SKB_CB(skb);
  251. if (!info->control.vif)
  252. goto err;
  253. vif = info->control.vif;
  254. bss = &vif->bss_conf;
  255. if (((vif->type == NL80211_IFTYPE_STATION) ||
  256. (vif->type == NL80211_IFTYPE_P2P_CLIENT)) &&
  257. (!bss->assoc))
  258. goto err;
  259. status = rsi_prepare_data_desc(common, skb);
  260. if (status)
  261. goto err;
  262. status = rsi_send_pkt_to_bus(common, skb);
  263. if (status)
  264. rsi_dbg(ERR_ZONE, "%s: Failed to write pkt\n", __func__);
  265. err:
  266. ++common->tx_stats.total_tx_pkt_freed[skb->priority];
  267. rsi_indicate_tx_status(adapter, skb, status);
  268. return status;
  269. }
  270. /**
  271. * rsi_send_mgmt_pkt() - This functions sends the received management packet
  272. * from driver to device.
  273. * @common: Pointer to the driver private structure.
  274. * @skb: Pointer to the socket buffer structure.
  275. *
  276. * Return: status: 0 on success, -1 on failure.
  277. */
  278. int rsi_send_mgmt_pkt(struct rsi_common *common,
  279. struct sk_buff *skb)
  280. {
  281. struct rsi_hw *adapter = common->priv;
  282. struct ieee80211_tx_info *info;
  283. struct skb_info *tx_params;
  284. int status = -E2BIG;
  285. info = IEEE80211_SKB_CB(skb);
  286. tx_params = (struct skb_info *)info->driver_data;
  287. if (tx_params->flags & INTERNAL_MGMT_PKT) {
  288. status = adapter->host_intf_ops->write_pkt(common->priv,
  289. (u8 *)skb->data,
  290. skb->len);
  291. if (status) {
  292. rsi_dbg(ERR_ZONE,
  293. "%s: Failed to write the packet\n", __func__);
  294. }
  295. dev_kfree_skb(skb);
  296. return status;
  297. }
  298. if (FRAME_DESC_SZ > skb_headroom(skb))
  299. goto err;
  300. rsi_prepare_mgmt_desc(common, skb);
  301. status = rsi_send_pkt_to_bus(common, skb);
  302. if (status)
  303. rsi_dbg(ERR_ZONE, "%s: Failed to write the packet\n", __func__);
  304. err:
  305. rsi_indicate_tx_status(common->priv, skb, status);
  306. return status;
  307. }
  308. int rsi_send_bt_pkt(struct rsi_common *common, struct sk_buff *skb)
  309. {
  310. int status = -EINVAL;
  311. u8 header_size = 0;
  312. struct rsi_bt_desc *bt_desc;
  313. u8 queueno = ((skb->data[1] >> 4) & 0xf);
  314. if (queueno == RSI_BT_MGMT_Q) {
  315. status = rsi_send_pkt_to_bus(common, skb);
  316. if (status)
  317. rsi_dbg(ERR_ZONE, "%s: Failed to write bt mgmt pkt\n",
  318. __func__);
  319. goto out;
  320. }
  321. header_size = FRAME_DESC_SZ;
  322. if (header_size > skb_headroom(skb)) {
  323. rsi_dbg(ERR_ZONE, "%s: Not enough headroom\n", __func__);
  324. status = -ENOSPC;
  325. goto out;
  326. }
  327. skb_push(skb, header_size);
  328. memset(skb->data, 0, header_size);
  329. bt_desc = (struct rsi_bt_desc *)skb->data;
  330. rsi_set_len_qno(&bt_desc->len_qno, (skb->len - FRAME_DESC_SZ),
  331. RSI_BT_DATA_Q);
  332. bt_desc->bt_pkt_type = cpu_to_le16(bt_cb(skb)->pkt_type);
  333. status = rsi_send_pkt_to_bus(common, skb);
  334. if (status)
  335. rsi_dbg(ERR_ZONE, "%s: Failed to write bt pkt\n", __func__);
  336. out:
  337. dev_kfree_skb(skb);
  338. return status;
  339. }
  340. int rsi_prepare_beacon(struct rsi_common *common, struct sk_buff *skb)
  341. {
  342. struct rsi_hw *adapter = (struct rsi_hw *)common->priv;
  343. struct rsi_data_desc *bcn_frm;
  344. struct ieee80211_hw *hw = common->priv->hw;
  345. struct ieee80211_conf *conf = &hw->conf;
  346. struct ieee80211_vif *vif;
  347. struct sk_buff *mac_bcn;
  348. u8 vap_id = 0, i;
  349. u16 tim_offset = 0;
  350. for (i = 0; i < RSI_MAX_VIFS; i++) {
  351. vif = adapter->vifs[i];
  352. if (!vif)
  353. continue;
  354. if ((vif->type == NL80211_IFTYPE_AP) ||
  355. (vif->type == NL80211_IFTYPE_P2P_GO))
  356. break;
  357. }
  358. if (!vif)
  359. return -EINVAL;
  360. mac_bcn = ieee80211_beacon_get_tim(adapter->hw,
  361. vif,
  362. &tim_offset, NULL);
  363. if (!mac_bcn) {
  364. rsi_dbg(ERR_ZONE, "Failed to get beacon from mac80211\n");
  365. return -EINVAL;
  366. }
  367. common->beacon_cnt++;
  368. bcn_frm = (struct rsi_data_desc *)skb->data;
  369. rsi_set_len_qno(&bcn_frm->len_qno, mac_bcn->len, RSI_WIFI_DATA_Q);
  370. bcn_frm->header_len = MIN_802_11_HDR_LEN;
  371. bcn_frm->frame_info = cpu_to_le16(RSI_DATA_DESC_MAC_BBP_INFO |
  372. RSI_DATA_DESC_NO_ACK_IND |
  373. RSI_DATA_DESC_BEACON_FRAME |
  374. RSI_DATA_DESC_INSERT_TSF |
  375. RSI_DATA_DESC_INSERT_SEQ_NO |
  376. RATE_INFO_ENABLE);
  377. bcn_frm->rate_info = cpu_to_le16(vap_id << 14);
  378. bcn_frm->qid_tid = BEACON_HW_Q;
  379. if (conf_is_ht40_plus(conf)) {
  380. bcn_frm->bbp_info = cpu_to_le16(LOWER_20_ENABLE);
  381. bcn_frm->bbp_info |= cpu_to_le16(LOWER_20_ENABLE >> 12);
  382. } else if (conf_is_ht40_minus(conf)) {
  383. bcn_frm->bbp_info = cpu_to_le16(UPPER_20_ENABLE);
  384. bcn_frm->bbp_info |= cpu_to_le16(UPPER_20_ENABLE >> 12);
  385. }
  386. if (common->band == NL80211_BAND_2GHZ)
  387. bcn_frm->bbp_info |= cpu_to_le16(RSI_RATE_1);
  388. else
  389. bcn_frm->bbp_info |= cpu_to_le16(RSI_RATE_6);
  390. if (mac_bcn->data[tim_offset + 2] == 0)
  391. bcn_frm->frame_info |= cpu_to_le16(RSI_DATA_DESC_DTIM_BEACON);
  392. memcpy(&skb->data[FRAME_DESC_SZ], mac_bcn->data, mac_bcn->len);
  393. skb_put(skb, mac_bcn->len + FRAME_DESC_SZ);
  394. dev_kfree_skb(mac_bcn);
  395. return 0;
  396. }
  397. static void bl_cmd_timeout(struct timer_list *t)
  398. {
  399. struct rsi_hw *adapter = from_timer(adapter, t, bl_cmd_timer);
  400. adapter->blcmd_timer_expired = true;
  401. del_timer(&adapter->bl_cmd_timer);
  402. }
  403. static int bl_start_cmd_timer(struct rsi_hw *adapter, u32 timeout)
  404. {
  405. timer_setup(&adapter->bl_cmd_timer, bl_cmd_timeout, 0);
  406. adapter->bl_cmd_timer.expires = (msecs_to_jiffies(timeout) + jiffies);
  407. adapter->blcmd_timer_expired = false;
  408. add_timer(&adapter->bl_cmd_timer);
  409. return 0;
  410. }
  411. static int bl_stop_cmd_timer(struct rsi_hw *adapter)
  412. {
  413. adapter->blcmd_timer_expired = false;
  414. if (timer_pending(&adapter->bl_cmd_timer))
  415. del_timer(&adapter->bl_cmd_timer);
  416. return 0;
  417. }
  418. static int bl_write_cmd(struct rsi_hw *adapter, u8 cmd, u8 exp_resp,
  419. u16 *cmd_resp)
  420. {
  421. struct rsi_host_intf_ops *hif_ops = adapter->host_intf_ops;
  422. u32 regin_val = 0, regout_val = 0;
  423. u32 regin_input = 0;
  424. u8 output = 0;
  425. int status;
  426. regin_input = (REGIN_INPUT | adapter->priv->coex_mode);
  427. while (!adapter->blcmd_timer_expired) {
  428. regin_val = 0;
  429. status = hif_ops->master_reg_read(adapter, SWBL_REGIN,
  430. &regin_val, 2);
  431. if (status < 0) {
  432. rsi_dbg(ERR_ZONE,
  433. "%s: Command %0x REGIN reading failed..\n",
  434. __func__, cmd);
  435. return status;
  436. }
  437. mdelay(1);
  438. if ((regin_val >> 12) != REGIN_VALID)
  439. break;
  440. }
  441. if (adapter->blcmd_timer_expired) {
  442. rsi_dbg(ERR_ZONE,
  443. "%s: Command %0x REGIN reading timed out..\n",
  444. __func__, cmd);
  445. return -ETIMEDOUT;
  446. }
  447. rsi_dbg(INFO_ZONE,
  448. "Issuing write to Regin val:%0x sending cmd:%0x\n",
  449. regin_val, (cmd | regin_input << 8));
  450. status = hif_ops->master_reg_write(adapter, SWBL_REGIN,
  451. (cmd | regin_input << 8), 2);
  452. if (status < 0)
  453. return status;
  454. mdelay(1);
  455. if (cmd == LOAD_HOSTED_FW || cmd == JUMP_TO_ZERO_PC) {
  456. /* JUMP_TO_ZERO_PC doesn't expect
  457. * any response. So return from here
  458. */
  459. return 0;
  460. }
  461. while (!adapter->blcmd_timer_expired) {
  462. regout_val = 0;
  463. status = hif_ops->master_reg_read(adapter, SWBL_REGOUT,
  464. &regout_val, 2);
  465. if (status < 0) {
  466. rsi_dbg(ERR_ZONE,
  467. "%s: Command %0x REGOUT reading failed..\n",
  468. __func__, cmd);
  469. return status;
  470. }
  471. mdelay(1);
  472. if ((regout_val >> 8) == REGOUT_VALID)
  473. break;
  474. }
  475. if (adapter->blcmd_timer_expired) {
  476. rsi_dbg(ERR_ZONE,
  477. "%s: Command %0x REGOUT reading timed out..\n",
  478. __func__, cmd);
  479. return status;
  480. }
  481. *cmd_resp = ((u16 *)&regout_val)[0] & 0xffff;
  482. output = ((u8 *)&regout_val)[0] & 0xff;
  483. status = hif_ops->master_reg_write(adapter, SWBL_REGOUT,
  484. (cmd | REGOUT_INVALID << 8), 2);
  485. if (status < 0) {
  486. rsi_dbg(ERR_ZONE,
  487. "%s: Command %0x REGOUT writing failed..\n",
  488. __func__, cmd);
  489. return status;
  490. }
  491. mdelay(1);
  492. if (output != exp_resp) {
  493. rsi_dbg(ERR_ZONE,
  494. "%s: Recvd resp %x for cmd %0x\n",
  495. __func__, output, cmd);
  496. return -EINVAL;
  497. }
  498. rsi_dbg(INFO_ZONE,
  499. "%s: Recvd Expected resp %x for cmd %0x\n",
  500. __func__, output, cmd);
  501. return 0;
  502. }
  503. static int bl_cmd(struct rsi_hw *adapter, u8 cmd, u8 exp_resp, char *str)
  504. {
  505. u16 regout_val = 0;
  506. u32 timeout;
  507. int status;
  508. if ((cmd == EOF_REACHED) || (cmd == PING_VALID) || (cmd == PONG_VALID))
  509. timeout = BL_BURN_TIMEOUT;
  510. else
  511. timeout = BL_CMD_TIMEOUT;
  512. bl_start_cmd_timer(adapter, timeout);
  513. status = bl_write_cmd(adapter, cmd, exp_resp, &regout_val);
  514. if (status < 0) {
  515. rsi_dbg(ERR_ZONE,
  516. "%s: Command %s (%0x) writing failed..\n",
  517. __func__, str, cmd);
  518. return status;
  519. }
  520. bl_stop_cmd_timer(adapter);
  521. return 0;
  522. }
  523. #define CHECK_SUM_OFFSET 20
  524. #define LEN_OFFSET 8
  525. #define ADDR_OFFSET 16
  526. static int bl_write_header(struct rsi_hw *adapter, u8 *flash_content,
  527. u32 content_size)
  528. {
  529. struct rsi_host_intf_ops *hif_ops = adapter->host_intf_ops;
  530. struct bl_header bl_hdr;
  531. u32 write_addr, write_len;
  532. int status;
  533. bl_hdr.flags = 0;
  534. bl_hdr.image_no = cpu_to_le32(adapter->priv->coex_mode);
  535. bl_hdr.check_sum = cpu_to_le32(
  536. *(u32 *)&flash_content[CHECK_SUM_OFFSET]);
  537. bl_hdr.flash_start_address = cpu_to_le32(
  538. *(u32 *)&flash_content[ADDR_OFFSET]);
  539. bl_hdr.flash_len = cpu_to_le32(*(u32 *)&flash_content[LEN_OFFSET]);
  540. write_len = sizeof(struct bl_header);
  541. if (adapter->rsi_host_intf == RSI_HOST_INTF_USB) {
  542. write_addr = PING_BUFFER_ADDRESS;
  543. status = hif_ops->write_reg_multiple(adapter, write_addr,
  544. (u8 *)&bl_hdr, write_len);
  545. if (status < 0) {
  546. rsi_dbg(ERR_ZONE,
  547. "%s: Failed to load Version/CRC structure\n",
  548. __func__);
  549. return status;
  550. }
  551. } else {
  552. write_addr = PING_BUFFER_ADDRESS >> 16;
  553. status = hif_ops->master_access_msword(adapter, write_addr);
  554. if (status < 0) {
  555. rsi_dbg(ERR_ZONE,
  556. "%s: Unable to set ms word to common reg\n",
  557. __func__);
  558. return status;
  559. }
  560. write_addr = RSI_SD_REQUEST_MASTER |
  561. (PING_BUFFER_ADDRESS & 0xFFFF);
  562. status = hif_ops->write_reg_multiple(adapter, write_addr,
  563. (u8 *)&bl_hdr, write_len);
  564. if (status < 0) {
  565. rsi_dbg(ERR_ZONE,
  566. "%s: Failed to load Version/CRC structure\n",
  567. __func__);
  568. return status;
  569. }
  570. }
  571. return 0;
  572. }
  573. static u32 read_flash_capacity(struct rsi_hw *adapter)
  574. {
  575. u32 flash_sz = 0;
  576. if ((adapter->host_intf_ops->master_reg_read(adapter, FLASH_SIZE_ADDR,
  577. &flash_sz, 2)) < 0) {
  578. rsi_dbg(ERR_ZONE,
  579. "%s: Flash size reading failed..\n",
  580. __func__);
  581. return 0;
  582. }
  583. rsi_dbg(INIT_ZONE, "Flash capacity: %d KiloBytes\n", flash_sz);
  584. return (flash_sz * 1024); /* Return size in kbytes */
  585. }
  586. static int ping_pong_write(struct rsi_hw *adapter, u8 cmd, u8 *addr, u32 size)
  587. {
  588. struct rsi_host_intf_ops *hif_ops = adapter->host_intf_ops;
  589. u32 block_size = adapter->block_size;
  590. u32 cmd_addr;
  591. u16 cmd_resp, cmd_req;
  592. u8 *str;
  593. int status;
  594. if (cmd == PING_WRITE) {
  595. cmd_addr = PING_BUFFER_ADDRESS;
  596. cmd_resp = PONG_AVAIL;
  597. cmd_req = PING_VALID;
  598. str = "PING_VALID";
  599. } else {
  600. cmd_addr = PONG_BUFFER_ADDRESS;
  601. cmd_resp = PING_AVAIL;
  602. cmd_req = PONG_VALID;
  603. str = "PONG_VALID";
  604. }
  605. status = hif_ops->load_data_master_write(adapter, cmd_addr, size,
  606. block_size, addr);
  607. if (status) {
  608. rsi_dbg(ERR_ZONE, "%s: Unable to write blk at addr %0x\n",
  609. __func__, *addr);
  610. return status;
  611. }
  612. status = bl_cmd(adapter, cmd_req, cmd_resp, str);
  613. if (status) {
  614. bl_stop_cmd_timer(adapter);
  615. return status;
  616. }
  617. return 0;
  618. }
  619. static int auto_fw_upgrade(struct rsi_hw *adapter, u8 *flash_content,
  620. u32 content_size)
  621. {
  622. u8 cmd, *temp_flash_content;
  623. u32 temp_content_size, num_flash, index;
  624. u32 flash_start_address;
  625. int status;
  626. temp_flash_content = flash_content;
  627. if (content_size > MAX_FLASH_FILE_SIZE) {
  628. rsi_dbg(ERR_ZONE,
  629. "%s: Flash Content size is more than 400K %u\n",
  630. __func__, MAX_FLASH_FILE_SIZE);
  631. return -EINVAL;
  632. }
  633. flash_start_address = *(u32 *)&flash_content[FLASH_START_ADDRESS];
  634. rsi_dbg(INFO_ZONE, "flash start address: %08x\n", flash_start_address);
  635. if (flash_start_address < FW_IMAGE_MIN_ADDRESS) {
  636. rsi_dbg(ERR_ZONE,
  637. "%s: Fw image Flash Start Address is less than 64K\n",
  638. __func__);
  639. return -EINVAL;
  640. }
  641. if (flash_start_address % FLASH_SECTOR_SIZE) {
  642. rsi_dbg(ERR_ZONE,
  643. "%s: Flash Start Address is not multiple of 4K\n",
  644. __func__);
  645. return -EINVAL;
  646. }
  647. if ((flash_start_address + content_size) > adapter->flash_capacity) {
  648. rsi_dbg(ERR_ZONE,
  649. "%s: Flash Content will cross max flash size\n",
  650. __func__);
  651. return -EINVAL;
  652. }
  653. temp_content_size = content_size;
  654. num_flash = content_size / FLASH_WRITE_CHUNK_SIZE;
  655. rsi_dbg(INFO_ZONE, "content_size: %d, num_flash: %d\n",
  656. content_size, num_flash);
  657. for (index = 0; index <= num_flash; index++) {
  658. rsi_dbg(INFO_ZONE, "flash index: %d\n", index);
  659. if (index != num_flash) {
  660. content_size = FLASH_WRITE_CHUNK_SIZE;
  661. rsi_dbg(INFO_ZONE, "QSPI content_size:%d\n",
  662. content_size);
  663. } else {
  664. content_size =
  665. temp_content_size % FLASH_WRITE_CHUNK_SIZE;
  666. rsi_dbg(INFO_ZONE,
  667. "Writing last sector content_size:%d\n",
  668. content_size);
  669. if (!content_size) {
  670. rsi_dbg(INFO_ZONE, "instruction size zero\n");
  671. break;
  672. }
  673. }
  674. if (index % 2)
  675. cmd = PING_WRITE;
  676. else
  677. cmd = PONG_WRITE;
  678. status = ping_pong_write(adapter, cmd, flash_content,
  679. content_size);
  680. if (status) {
  681. rsi_dbg(ERR_ZONE, "%s: Unable to load %d block\n",
  682. __func__, index);
  683. return status;
  684. }
  685. rsi_dbg(INFO_ZONE,
  686. "%s: Successfully loaded %d instructions\n",
  687. __func__, index);
  688. flash_content += content_size;
  689. }
  690. status = bl_cmd(adapter, EOF_REACHED, FW_LOADING_SUCCESSFUL,
  691. "EOF_REACHED");
  692. if (status) {
  693. bl_stop_cmd_timer(adapter);
  694. return status;
  695. }
  696. rsi_dbg(INFO_ZONE, "FW loading is done and FW is running..\n");
  697. return 0;
  698. }
  699. static int rsi_load_firmware(struct rsi_hw *adapter)
  700. {
  701. struct rsi_common *common = adapter->priv;
  702. struct rsi_host_intf_ops *hif_ops = adapter->host_intf_ops;
  703. const struct firmware *fw_entry = NULL;
  704. u32 regout_val = 0, content_size;
  705. u16 tmp_regout_val = 0;
  706. u8 *flash_content = NULL;
  707. struct ta_metadata *metadata_p;
  708. int status;
  709. bl_start_cmd_timer(adapter, BL_CMD_TIMEOUT);
  710. while (!adapter->blcmd_timer_expired) {
  711. status = hif_ops->master_reg_read(adapter, SWBL_REGOUT,
  712. &regout_val, 2);
  713. if (status < 0) {
  714. rsi_dbg(ERR_ZONE,
  715. "%s: REGOUT read failed\n", __func__);
  716. return status;
  717. }
  718. mdelay(1);
  719. if ((regout_val >> 8) == REGOUT_VALID)
  720. break;
  721. }
  722. if (adapter->blcmd_timer_expired) {
  723. rsi_dbg(ERR_ZONE, "%s: REGOUT read timedout\n", __func__);
  724. rsi_dbg(ERR_ZONE,
  725. "%s: Soft boot loader not present\n", __func__);
  726. return -ETIMEDOUT;
  727. }
  728. bl_stop_cmd_timer(adapter);
  729. rsi_dbg(INFO_ZONE, "Received Board Version Number: %x\n",
  730. (regout_val & 0xff));
  731. status = hif_ops->master_reg_write(adapter, SWBL_REGOUT,
  732. (REGOUT_INVALID | REGOUT_INVALID << 8),
  733. 2);
  734. if (status < 0) {
  735. rsi_dbg(ERR_ZONE, "%s: REGOUT writing failed..\n", __func__);
  736. return status;
  737. }
  738. mdelay(1);
  739. status = bl_cmd(adapter, CONFIG_AUTO_READ_MODE, CMD_PASS,
  740. "AUTO_READ_CMD");
  741. if (status < 0)
  742. return status;
  743. adapter->flash_capacity = read_flash_capacity(adapter);
  744. if (adapter->flash_capacity <= 0) {
  745. rsi_dbg(ERR_ZONE,
  746. "%s: Unable to read flash size from EEPROM\n",
  747. __func__);
  748. return -EINVAL;
  749. }
  750. metadata_p = &metadata_flash_content[adapter->priv->coex_mode];
  751. rsi_dbg(INIT_ZONE, "%s: Loading file %s\n", __func__, metadata_p->name);
  752. adapter->fw_file_name = metadata_p->name;
  753. status = request_firmware(&fw_entry, metadata_p->name, adapter->device);
  754. if (status < 0) {
  755. rsi_dbg(ERR_ZONE, "%s: Failed to open file %s\n",
  756. __func__, metadata_p->name);
  757. return status;
  758. }
  759. flash_content = kmemdup(fw_entry->data, fw_entry->size, GFP_KERNEL);
  760. if (!flash_content) {
  761. rsi_dbg(ERR_ZONE, "%s: Failed to copy firmware\n", __func__);
  762. status = -EIO;
  763. goto fail;
  764. }
  765. content_size = fw_entry->size;
  766. rsi_dbg(INFO_ZONE, "FW Length = %d bytes\n", content_size);
  767. /* Get the firmware version */
  768. common->lmac_ver.ver.info.fw_ver[0] =
  769. flash_content[LMAC_VER_OFFSET] & 0xFF;
  770. common->lmac_ver.ver.info.fw_ver[1] =
  771. flash_content[LMAC_VER_OFFSET + 1] & 0xFF;
  772. common->lmac_ver.major = flash_content[LMAC_VER_OFFSET + 2] & 0xFF;
  773. common->lmac_ver.release_num =
  774. flash_content[LMAC_VER_OFFSET + 3] & 0xFF;
  775. common->lmac_ver.minor = flash_content[LMAC_VER_OFFSET + 4] & 0xFF;
  776. common->lmac_ver.patch_num = 0;
  777. rsi_print_version(common);
  778. status = bl_write_header(adapter, flash_content, content_size);
  779. if (status) {
  780. rsi_dbg(ERR_ZONE,
  781. "%s: RPS Image header loading failed\n",
  782. __func__);
  783. goto fail;
  784. }
  785. bl_start_cmd_timer(adapter, BL_CMD_TIMEOUT);
  786. status = bl_write_cmd(adapter, CHECK_CRC, CMD_PASS, &tmp_regout_val);
  787. if (status) {
  788. bl_stop_cmd_timer(adapter);
  789. rsi_dbg(ERR_ZONE,
  790. "%s: CHECK_CRC Command writing failed..\n",
  791. __func__);
  792. if ((tmp_regout_val & 0xff) == CMD_FAIL) {
  793. rsi_dbg(ERR_ZONE,
  794. "CRC Fail.. Proceeding to Upgrade mode\n");
  795. goto fw_upgrade;
  796. }
  797. }
  798. bl_stop_cmd_timer(adapter);
  799. status = bl_cmd(adapter, POLLING_MODE, CMD_PASS, "POLLING_MODE");
  800. if (status)
  801. goto fail;
  802. load_image_cmd:
  803. status = bl_cmd(adapter, LOAD_HOSTED_FW, LOADING_INITIATED,
  804. "LOAD_HOSTED_FW");
  805. if (status)
  806. goto fail;
  807. rsi_dbg(INFO_ZONE, "Load Image command passed..\n");
  808. goto success;
  809. fw_upgrade:
  810. status = bl_cmd(adapter, BURN_HOSTED_FW, SEND_RPS_FILE, "FW_UPGRADE");
  811. if (status)
  812. goto fail;
  813. rsi_dbg(INFO_ZONE, "Burn Command Pass.. Upgrading the firmware\n");
  814. status = auto_fw_upgrade(adapter, flash_content, content_size);
  815. if (status == 0) {
  816. rsi_dbg(ERR_ZONE, "Firmware upgradation Done\n");
  817. goto load_image_cmd;
  818. }
  819. rsi_dbg(ERR_ZONE, "Firmware upgrade failed\n");
  820. status = bl_cmd(adapter, CONFIG_AUTO_READ_MODE, CMD_PASS,
  821. "AUTO_READ_MODE");
  822. if (status)
  823. goto fail;
  824. success:
  825. rsi_dbg(ERR_ZONE, "***** Firmware Loading successful *****\n");
  826. kfree(flash_content);
  827. release_firmware(fw_entry);
  828. return 0;
  829. fail:
  830. rsi_dbg(ERR_ZONE, "##### Firmware loading failed #####\n");
  831. kfree(flash_content);
  832. release_firmware(fw_entry);
  833. return status;
  834. }
  835. int rsi_hal_device_init(struct rsi_hw *adapter)
  836. {
  837. struct rsi_common *common = adapter->priv;
  838. switch (adapter->device_model) {
  839. case RSI_DEV_9113:
  840. if (rsi_load_firmware(adapter)) {
  841. rsi_dbg(ERR_ZONE,
  842. "%s: Failed to load TA instructions\n",
  843. __func__);
  844. return -EINVAL;
  845. }
  846. break;
  847. default:
  848. return -EINVAL;
  849. }
  850. common->fsm_state = FSM_CARD_NOT_READY;
  851. return 0;
  852. }
  853. EXPORT_SYMBOL_GPL(rsi_hal_device_init);