/****************************************************************************** * * Name: MrvDrvShutdownHandler() * * Description: NDIS miniport shutdown event handler * * * Arguments: IN NDIS_HANDLE MiniportAdapterContext * Miniport context * * Return Value: None * * * Notes: * *****************************************************************************/ VOID MrvDrvShutdownHandler( IN NDIS_HANDLE MiniportAdapterContext ) { PMRVDRV_ADAPTER Adapter; DBGPRINT(DBG_UNLOAD|DBG_ERROR,(L"+MrvDrvShutdownHandler()\n")); Adapter = (PMRVDRV_ADAPTER)MiniportAdapterContext; // Shutdown the NIC // PrepareAndSendCommand( Adapter, HostCmd_CMD_802_11_RESET, HostCmd_ACT_HALT, HostCmd_OPTION_NO_INT, (NDIS_OID)0, HostCmd_PENDING_ON_NONE, 0, FALSE, NULL, NULL, NULL, NULL); DBGPRINT(DBG_LOAD,(L"-MrvDrvShutdownHandler()\n")); return; }
/** * @brief This function sets the MAC address to firmware. * * @param priv A pointer to wlan_private structure * @param pRxPD A pointer to RxPD structure of received packet * @return WLAN_STATUS_SUCCESS or WLAN_STATUS_FAILURE */ int wlan_set_mac_address(struct eth_drv_sc *sc, void *addr) { int ret = WLAN_STATUS_SUCCESS; wlan_private *priv = (wlan_private *) sc->driver_private; wlan_adapter *Adapter = priv->adapter; // struct sockaddr *pHwAddr = (struct sockaddr *) addr; ENTER(); memset(Adapter->CurrentAddr, 0, MRVDRV_ETH_ADDR_LEN); /* dev->dev_addr is 8 bytes */ // HEXDUMP("dev->dev_addr:", dev->dev_addr, ETH_ALEN); //HEXDUMP("addr:", pHwAddr->sa_data, ETH_ALEN); memcpy(Adapter->CurrentAddr, addr, ETH_ALEN); ret = PrepareAndSendCommand(priv, HostCmd_CMD_802_11_MAC_ADDRESS, HostCmd_ACT_SET, HostCmd_OPTION_WAITFORRSP, 0, NULL); if (ret) { diag_printf("set mac address failed.\n"); ret = WLAN_STATUS_FAILURE; goto done; } HEXDUMP("Adapter->MacAddr:", Adapter->CurrentAddr, ETH_ALEN); // memcpy(dev->dev_addr, Adapter->CurrentAddr, ETH_ALEN); done: LEAVE(); return ret; }
/** * @brief This function sets multicast addresses to firmware * * @param dev A pointer to net_device structure * @return n/a */ static void wlan_set_multicast_list(struct eth_drv_sc *sc/*struct net_device *dev*/) { wlan_private *priv = (wlan_private *)sc->driver_private; wlan_adapter *Adapter = priv->adapter; int OldPacketFilter; #if 0 ENTER(); OldPacketFilter = Adapter->CurrentPacketFilter; if (dev->flags & IFF_PROMISC) { diag_printf("Enable Promiscuous mode\n"); Adapter->CurrentPacketFilter |= HostCmd_ACT_MAC_PROMISCUOUS_ENABLE; Adapter->CurrentPacketFilter &= ~(HostCmd_ACT_MAC_ALL_MULTICAST_ENABLE | HostCmd_ACT_MAC_MULTICAST_ENABLE); } else { /* Multicast */ Adapter->CurrentPacketFilter &= ~HostCmd_ACT_MAC_PROMISCUOUS_ENABLE; if (dev->flags & IFF_ALLMULTI || dev->mc_count > MRVDRV_MAX_MULTICAST_LIST_SIZE) { diag_printf("Enabling All Multicast!\n"); Adapter->CurrentPacketFilter |= HostCmd_ACT_MAC_ALL_MULTICAST_ENABLE; Adapter->CurrentPacketFilter &= ~HostCmd_ACT_MAC_MULTICAST_ENABLE; } else { Adapter->CurrentPacketFilter &= ~HostCmd_ACT_MAC_ALL_MULTICAST_ENABLE; if (!dev->mc_count) { diag_printf("No multicast addresses - " "disabling multicast!\n"); Adapter->CurrentPacketFilter &= ~HostCmd_ACT_MAC_MULTICAST_ENABLE; } else { int i; Adapter->CurrentPacketFilter |= HostCmd_ACT_MAC_MULTICAST_ENABLE; Adapter->NumOfMulticastMACAddr = CopyMulticastAddrs(Adapter, dev); diag_printf("Multicast addresses: %d\n", dev->mc_count); for (i = 0; i < dev->mc_count; i++) { diag_printf("Multicast address %d:" "%x %x %x %x %x %x\n", i, Adapter->MulticastList[i][0], Adapter->MulticastList[i][1], Adapter->MulticastList[i][2], Adapter->MulticastList[i][3], Adapter->MulticastList[i][4], Adapter->MulticastList[i][5]); } /* set multicast addresses to firmware */ PrepareAndSendCommand(priv, HostCmd_CMD_MAC_MULTICAST_ADR, HostCmd_ACT_GEN_SET, 0, 0, NULL); } } } if (Adapter->CurrentPacketFilter != OldPacketFilter) { SetMacPacketFilter(priv); } LEAVE(); #endif }
/** * @brief This function removes the card. * * @param priv A pointer to card * @return WLAN_STATUS_SUCCESS */ static int wlan_remove_card(void *card) { wlan_private *priv = &w99702_priv_data0; wlan_adapter *Adapter; //struct net_device *dev; struct cyg_netdevtab_entry *dev; struct eth_drv_sc *sc; union iwreq_data wrqu; ENTER(); if (!priv) { LEAVE(); return WLAN_STATUS_SUCCESS; } Adapter = priv->adapter; if (!Adapter) { LEAVE(); return WLAN_STATUS_SUCCESS; } dev = priv->wlan_dev.netdev; sc = (struct eth_drv_sc *)dev->device_instance; // wake_up_interruptible(&Adapter->ds_awake_q); cyg_cond_broadcast(&Adapter->ds_cond_q); if (Adapter->CurCmd) { diag_printf("Wake up current cmdwait_q\n"); // wake_up_interruptible(&Adapter->CurCmd->cmdwait_q); cyg_flag_setbits( &Adapter->CurCmd->cmdwait_flag_q, 3 ); } Adapter->CurCmd = NULL; if (Adapter->PSMode == Wlan802_11PowerModeMAX_PSP) { Adapter->PSMode = Wlan802_11PowerModeCAM; PSWakeup(priv, HostCmd_OPTION_WAITFORRSP); } if (Adapter->IsDeepSleep == TRUE) { Adapter->IsDeepSleep = FALSE; sbi_exit_deep_sleep(priv); } memset(wrqu.ap_addr.sa_data, 0xaa, ETH_ALEN); wrqu.ap_addr.sa_family = ARPHRD_ETHER; wireless_send_event(priv->wlan_dev.netdev, SIOCGIWAP, &wrqu, NULL); /* Disable interrupts on the card as we cannot handle them after RESET */ sbi_disable_host_int(priv); PrepareAndSendCommand(priv, HostCmd_CMD_802_11_RESET, 0, 0, 0, NULL); cyg_thread_delay(20); //udelay(200*1000); #ifdef ENABLE_PM pm_unregister(wlan_pm_dev); #endif /* Flush all the packets upto the OS before stopping */ // wlan_send_rxskbQ(priv); eth_drv_dsr(0, 0, (cyg_addrword_t)sc); cleanup_txqueues(priv); // os_stop_queue(priv); // os_carrier_off(priv); Adapter->SurpriseRemoved = TRUE; /* Stop the thread servicing the interrupts */ //wake_up_interruptible(&priv->MainThread.waitQ); cyg_flag_setbits( &priv->MainThread.waitQ_flag_q, 1 ); #ifdef REASSOCIATION //wake_up_interruptible(&priv->ReassocThread.waitQ); cyg_flag_setbits( &priv->ReassocThread.waitQ_flag_q, 1 ); #endif /* REASSOCIATION */ #ifdef PROC_DEBUG wlan_debug_remove(priv); #endif // wlan_proc_remove(priv); diag_printf("unregester dev\n"); sbi_unregister_dev(priv); diag_printf("Free Adapter\n"); wlan_free_adapter(priv); /* Last reference is our one */ // diag_printf("refcnt = %d\n", atomic_read(&dev->refcnt)); // diag_printf("netdev_finish_unregister: %s%s.\n", dev->name, // (dev->features & NETIF_F_DYNALLOC) ? "" : ", old style"); // unregister_netdev(dev); diag_printf("Unregister finish\n"); priv->wlan_dev.netdev = NULL; //free_netdev(dev); //wlanpriv = NULL; LEAVE(); return WLAN_STATUS_SUCCESS; }
/** * @brief This function downloads firmware image, gets * HW spec from firmware and set basic parameters to * firmware. * * @param priv A pointer to wlan_private structure * @return WLAN_STATUS_SUCCESS or WLAN_STATUS_FAILURE */ int wlan_setup_station_hw(wlan_private * priv) { int ret = WLAN_STATUS_SUCCESS; wlan_adapter *adapter = priv->adapter; struct net_device *dev = priv->wlan_dev.netdev; ENTER(); if (netif_running(dev)) netif_device_detach(dev); sbi_disable_host_int(priv); /* Download the helper */ ret = sbi_prog_helper(priv); if (ret) { PRINTM(INFO, "Bootloader in invalid state!\n"); ret = WLAN_STATUS_FAILURE; goto done; } /* Download the main firmware via the helper firmware */ if (sbi_prog_firmware_w_helper(priv)) { PRINTM(INFO, "Wlan FW download failed!\n"); ret = WLAN_STATUS_FAILURE; goto done; } /* check if the fimware is downloaded successfully or not */ if (sbi_verify_fw_download(priv)) { PRINTM(INFO, "FW failed to be active in time!\n"); ret = WLAN_STATUS_FAILURE; goto done; } priv->adapter->fwstate = FW_STATE_READY; if (netif_running(dev)) netif_device_attach(dev); #define RF_REG_OFFSET 0x07 #define RF_REG_VALUE 0xc8 sbi_enable_host_int(priv); #ifdef MFG_CMD_SUPPORT if (mfgmode == 0) { #endif /* * Read MAC address from HW */ memset(adapter->CurrentAddr, 0xff, MRVDRV_ETH_ADDR_LEN); ret = PrepareAndSendCommand(priv, HostCmd_CMD_GET_HW_SPEC, 0, HostCmd_OPTION_WAITFORRSP, 0, NULL); if (ret) { ret = WLAN_STATUS_FAILURE; goto done; } SetMacPacketFilter(priv); ret = PrepareAndSendCommand(priv, HostCmd_CMD_802_11_FW_WAKEUP_METHOD, HostCmd_ACT_GET, HostCmd_OPTION_WAITFORRSP, 0, &priv->adapter->fwWakeupMethod); if (ret) { ret = WLAN_STATUS_FAILURE; goto done; } #ifdef MFG_CMD_SUPPORT } #endif #ifdef MFG_CMD_SUPPORT if (mfgmode == 0) { #endif ret = PrepareAndSendCommand(priv, HostCmd_CMD_802_11_RATE_ADAPT_RATESET, HostCmd_ACT_GEN_GET, HostCmd_OPTION_WAITFORRSP, 0, NULL); if (ret) { ret = WLAN_STATUS_FAILURE; goto done; } priv->adapter->DataRate = 0; ret = PrepareAndSendCommand(priv, HostCmd_CMD_802_11_RF_TX_POWER, HostCmd_ACT_GEN_GET, HostCmd_OPTION_WAITFORRSP, 0, NULL); if (ret) { ret = WLAN_STATUS_FAILURE; goto done; } #ifdef MFG_CMD_SUPPORT } #endif ret = WLAN_STATUS_SUCCESS; done: LEAVE(); return (ret); }