p2p_state.c 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. #include "p2p_precomp.h"
  2. BOOLEAN
  3. p2pStateInit_IDLE(IN P_ADAPTER_T prAdapter,
  4. IN P_P2P_FSM_INFO_T prP2pFsmInfo, IN P_BSS_INFO_T prP2pBssInfo, OUT P_ENUM_P2P_STATE_T peNextState)
  5. {
  6. BOOLEAN fgIsTransOut = FALSE;
  7. /* P_P2P_CHNL_REQ_INFO_T prChnlReqInfo = (P_P2P_CHNL_REQ_INFO_T)NULL; */
  8. do {
  9. ASSERT_BREAK((prAdapter != NULL) &&
  10. (prP2pFsmInfo != NULL) && (prP2pBssInfo != NULL) && (peNextState != NULL));
  11. if ((prP2pBssInfo->eIntendOPMode == OP_MODE_ACCESS_POINT)
  12. && IS_NET_PWR_STATE_ACTIVE(prAdapter, NETWORK_TYPE_P2P_INDEX)) {
  13. P_P2P_CHNL_REQ_INFO_T prChnlReqInfo = &(prP2pFsmInfo->rChnlReqInfo);
  14. fgIsTransOut = TRUE;
  15. prChnlReqInfo->eChannelReqType = CHANNEL_REQ_TYPE_GO_START_BSS;
  16. *peNextState = P2P_STATE_REQING_CHANNEL;
  17. } else {
  18. #if 0
  19. else
  20. if (IS_NET_PWR_STATE_ACTIVE(prAdapter, NETWORK_TYPE_P2P_INDEX)) {
  21. ASSERT((prP2pBssInfo->eCurrentOPMode == OP_MODE_ACCESS_POINT) ||
  22. (prP2pBssInfo->eCurrentOPMode == OP_MODE_INFRASTRUCTURE));
  23. prChnlReqInfo = &prP2pFsmInfo->rChnlReqInfo;
  24. if (prChnlReqInfo->fgIsChannelRequested) {
  25. /* Start a timer for return channel. */
  26. DBGLOG(P2P, TRACE, "start a GO channel timer.\n");
  27. }
  28. }
  29. #endif
  30. cnmTimerStartTimer(prAdapter, &(prP2pFsmInfo->rP2pFsmTimeoutTimer), 5000);
  31. }
  32. } while (FALSE);
  33. return fgIsTransOut;
  34. } /* p2pStateInit_IDLE */
  35. VOID p2pStateAbort_IDLE(IN P_ADAPTER_T prAdapter, IN P_P2P_FSM_INFO_T prP2pFsmInfo, IN ENUM_P2P_STATE_T eNextState)
  36. {
  37. P_P2P_CHNL_REQ_INFO_T prChnlReqInfo = (P_P2P_CHNL_REQ_INFO_T) NULL;
  38. do {
  39. ASSERT_BREAK((prAdapter != NULL) && (prP2pFsmInfo != NULL));
  40. prChnlReqInfo = &prP2pFsmInfo->rChnlReqInfo;
  41. if (prChnlReqInfo->fgIsChannelRequested) {
  42. /* Release channel before timeout. */
  43. p2pFuncReleaseCh(prAdapter, prChnlReqInfo);
  44. }
  45. /* Stop timer for leaving this state. */
  46. cnmTimerStopTimer(prAdapter, &(prP2pFsmInfo->rP2pFsmTimeoutTimer));
  47. } while (FALSE);
  48. } /* p2pStateAbort_IDLE */
  49. VOID p2pStateInit_CHNL_ON_HAND(IN P_ADAPTER_T prAdapter, IN P_BSS_INFO_T prP2pBssInfo, IN P_P2P_FSM_INFO_T prP2pFsmInfo)
  50. {
  51. P_P2P_CHNL_REQ_INFO_T prChnlReqInfo = (P_P2P_CHNL_REQ_INFO_T) NULL;
  52. do {
  53. ASSERT_BREAK((prAdapter != NULL) && (prP2pFsmInfo != NULL));
  54. prChnlReqInfo = &(prP2pFsmInfo->rChnlReqInfo);
  55. /* Store the original channel info. */
  56. prChnlReqInfo->ucOriChnlNum = prP2pBssInfo->ucPrimaryChannel;
  57. prChnlReqInfo->eOriBand = prP2pBssInfo->eBand;
  58. prChnlReqInfo->eOriChnlSco = prP2pBssInfo->eBssSCO;
  59. /* RX Probe Request would check primary channel. */
  60. prP2pBssInfo->ucPrimaryChannel = prChnlReqInfo->ucReqChnlNum;
  61. prP2pBssInfo->eBand = prChnlReqInfo->eBand;
  62. prP2pBssInfo->eBssSCO = prChnlReqInfo->eChnlSco;
  63. DBGLOG(P2P, TRACE, "start a channel on hand timer.\n");
  64. cnmTimerStartTimer(prAdapter, &(prP2pFsmInfo->rP2pFsmTimeoutTimer), prChnlReqInfo->u4MaxInterval);
  65. kalP2PIndicateChannelReady(prAdapter->prGlueInfo,
  66. prChnlReqInfo->u8Cookie,
  67. prChnlReqInfo->ucReqChnlNum,
  68. prChnlReqInfo->eBand, prChnlReqInfo->eChnlSco, prChnlReqInfo->u4MaxInterval);
  69. } while (FALSE);
  70. } /* p2pStateInit_CHNL_ON_HAND */
  71. VOID
  72. p2pStateAbort_CHNL_ON_HAND(IN P_ADAPTER_T prAdapter,
  73. IN P_P2P_FSM_INFO_T prP2pFsmInfo,
  74. IN P_BSS_INFO_T prP2pBssInfo, IN ENUM_P2P_STATE_T eNextState)
  75. {
  76. P_P2P_CHNL_REQ_INFO_T prChnlReqInfo = (P_P2P_CHNL_REQ_INFO_T) NULL;
  77. do {
  78. ASSERT_BREAK((prAdapter != NULL) && (prP2pFsmInfo != NULL));
  79. prChnlReqInfo = &(prP2pFsmInfo->rChnlReqInfo);
  80. cnmTimerStopTimer(prAdapter, &(prP2pFsmInfo->rP2pFsmTimeoutTimer));
  81. /* Restore the original channel info. */
  82. prP2pBssInfo->ucPrimaryChannel = prChnlReqInfo->ucOriChnlNum;
  83. prP2pBssInfo->eBand = prChnlReqInfo->eOriBand;
  84. prP2pBssInfo->eBssSCO = prChnlReqInfo->eOriChnlSco;
  85. #if 0
  86. if (eNextState != P2P_STATE_CHNL_ON_HAND) {
  87. /* Indicate channel return. */
  88. kalP2PIndicateChannelExpired(prAdapter->prGlueInfo, &prP2pFsmInfo->rChnlReqInfo);
  89. /* Return Channel. */
  90. p2pFuncReleaseCh(prAdapter, &(prP2pFsmInfo->rChnlReqInfo));
  91. }
  92. #endif
  93. } while (FALSE);
  94. } /* p2pStateAbort_CHNL_ON_HAND */
  95. VOID
  96. p2pStateAbort_REQING_CHANNEL(IN P_ADAPTER_T prAdapter, IN P_P2P_FSM_INFO_T prP2pFsmInfo, IN ENUM_P2P_STATE_T eNextState)
  97. {
  98. P_BSS_INFO_T prP2pBssInfo = (P_BSS_INFO_T) NULL;
  99. P_P2P_SPECIFIC_BSS_INFO_T prP2pSpecificBssInfo = (P_P2P_SPECIFIC_BSS_INFO_T) NULL;
  100. do {
  101. ASSERT_BREAK((prAdapter != NULL) && (prP2pFsmInfo != NULL) && (eNextState < P2P_STATE_NUM));
  102. prP2pBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_P2P_INDEX]);
  103. prP2pSpecificBssInfo = prAdapter->rWifiVar.prP2pSpecificBssInfo;
  104. if (eNextState == P2P_STATE_IDLE) {
  105. if (prP2pBssInfo->eIntendOPMode == OP_MODE_ACCESS_POINT) {
  106. /* Intend to be AP. */
  107. /* Setup for AP mode. */
  108. #if 0
  109. p2pFuncStartGO(prAdapter,
  110. prP2pBssInfo,
  111. prP2pSpecificBssInfo->aucGroupSsid,
  112. prP2pSpecificBssInfo->u2GroupSsidLen,
  113. prP2pSpecificBssInfo->ucPreferredChannel,
  114. prP2pSpecificBssInfo->eRfBand,
  115. prP2pSpecificBssInfo->eRfSco, prP2pFsmInfo->fgIsApMode);
  116. #endif
  117. } else {
  118. /* Return Channel. */
  119. p2pFuncReleaseCh(prAdapter, &(prP2pFsmInfo->rChnlReqInfo));
  120. }
  121. }
  122. } while (FALSE);
  123. } /* p2pStateInit_AP_CHANNEL_DETECT */
  124. VOID
  125. p2pStateAbort_AP_CHANNEL_DETECT(IN P_ADAPTER_T prAdapter,
  126. IN P_P2P_FSM_INFO_T prP2pFsmInfo,
  127. IN P_P2P_SPECIFIC_BSS_INFO_T prP2pSpecificBssInfo, IN ENUM_P2P_STATE_T eNextState)
  128. {
  129. P_P2P_CHNL_REQ_INFO_T prChnlReqInfo = (P_P2P_CHNL_REQ_INFO_T) NULL;
  130. P_P2P_CONNECTION_SETTINGS_T prP2pConnSettings = (P_P2P_CONNECTION_SETTINGS_T) NULL;
  131. do {
  132. if (eNextState == P2P_STATE_REQING_CHANNEL) {
  133. UINT_8 ucPreferedChnl = 0;
  134. ENUM_BAND_T eBand = BAND_NULL;
  135. ENUM_CHNL_EXT_T eSco = CHNL_EXT_SCN;
  136. prChnlReqInfo = &(prP2pFsmInfo->rChnlReqInfo);
  137. /* Determine the channel for AP. */
  138. if (cnmPreferredChannel(prAdapter, &eBand, &ucPreferedChnl, &eSco) == FALSE) {
  139. #if 0
  140. prP2pConnSettings = prAdapter->rWifiVar.prP2PConnSettings;
  141. ucPreferedChnl = prP2pConnSettings->ucOperatingChnl;
  142. if ((ucPreferedChnl) == 0) {
  143. if (scnQuerySparseChannel(prAdapter, &eBand, &ucPreferedChnl) == FALSE) {
  144. /* What to do? */
  145. ASSERT(FALSE);
  146. /* TODO: Pick up a valid channel from channel list. */
  147. }
  148. }
  149. #endif
  150. }
  151. prChnlReqInfo->eChannelReqType = CHANNEL_REQ_TYPE_GO_START_BSS;
  152. prChnlReqInfo->ucReqChnlNum = prP2pSpecificBssInfo->ucPreferredChannel = ucPreferedChnl;
  153. prChnlReqInfo->eBand = prP2pSpecificBssInfo->eRfBand = eBand;
  154. prChnlReqInfo->eChnlSco = prP2pSpecificBssInfo->eRfSco = eSco;
  155. } else {
  156. /* p2pFuncCancelScan(prAdapter, &(prP2pFsmInfo->rScanReqInfo)); */
  157. }
  158. } while (FALSE);
  159. } /* p2pStateAbort_AP_CHANNEL_DETECT */
  160. /*----------------------------------------------------------------------------*/
  161. /*!
  162. * @brief Process of JOIN Abort. Leave JOIN State & Abort JOIN.
  163. *
  164. * @param (none)
  165. *
  166. * @return (none)
  167. */
  168. /*----------------------------------------------------------------------------*/
  169. VOID
  170. p2pStateAbort_GC_JOIN(IN P_ADAPTER_T prAdapter,
  171. IN P_P2P_FSM_INFO_T prP2pFsmInfo, IN P_P2P_JOIN_INFO_T prJoinInfo, IN ENUM_P2P_STATE_T eNextState)
  172. {
  173. P_MSG_JOIN_ABORT_T prJoinAbortMsg = (P_MSG_JOIN_ABORT_T) NULL;
  174. do {
  175. ASSERT_BREAK((prAdapter != NULL) && (prP2pFsmInfo != NULL) && (prJoinInfo != NULL));
  176. if (prJoinInfo->fgIsJoinComplete == FALSE) {
  177. prJoinAbortMsg =
  178. (P_MSG_JOIN_ABORT_T) cnmMemAlloc(prAdapter, RAM_TYPE_MSG, sizeof(MSG_JOIN_ABORT_T));
  179. if (!prJoinAbortMsg) {
  180. DBGLOG(P2P, TRACE, "Fail to allocate join abort message buffer\n");
  181. ASSERT(FALSE);
  182. return;
  183. }
  184. prJoinAbortMsg->rMsgHdr.eMsgId = MID_P2P_SAA_FSM_ABORT;
  185. prJoinAbortMsg->ucSeqNum = prJoinInfo->ucSeqNumOfReqMsg;
  186. prJoinAbortMsg->prStaRec = prJoinInfo->prTargetStaRec;
  187. mboxSendMsg(prAdapter, MBOX_ID_0, (P_MSG_HDR_T) prJoinAbortMsg, MSG_SEND_METHOD_BUF);
  188. }
  189. /* Stop Join Timer. */
  190. cnmTimerStopTimer(prAdapter, &(prP2pFsmInfo->rP2pFsmTimeoutTimer));
  191. /* Release channel requested. */
  192. p2pFuncReleaseCh(prAdapter, &(prP2pFsmInfo->rChnlReqInfo));
  193. } while (FALSE);
  194. return;
  195. } /* p2pStateAbort_GC_JOIN */