4.7 Running in the WILCS02 Station Mode

The section describes how to run the WILCS02 device in the Station mode and connect to an AP.
  1. Initialize the WILCS02 driver module using the following command:
    Welcome to Buildroot
    buildroot login: root
    root@buildroot ~]# modprobe wilc-sdio
    linux_sdio_probe init_power =0
    wilc_sdio mmc0:0001:1: Driver Initializing success
  2. Start the WPA supplicant service and execute wpa_supplicant using the following command:
    # wpa_supplicant -iwlan0 -Dnl80211 -c /etc/wilc_wpa_supplicant.conf &
    # Successfully initialized wpa_supplicant
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_mgmt_frame_register]Frame registering Frame Type:
    d0: Boolean: 1
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_mgmt_frame_register]Return since mac is closed
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_mac_open]MAC OPEN[d464f800] wlan0
    WILC POWER UP
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_init_host_int]Host[d464f800][d463b000]
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_mac_open]*** re-init ***
    wilc_sdio mmc0:0001:1 wlan0: INFO [wlan_init_locks]Initializing Locks ...
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_wlan_init]Initializing WILC_Wlan
    wilc_sdio mmc0:0001:1: SDIO speed: 50000000
    wilc_sdio mmc0:0001:1: chipid 001003a0
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_wlan_initialize]WILC Initialization done
    wilc_sdio mmc0:0001:1 wlan0: INFO [init_irq]IRQ request succeeded IRQ-NUM= 137 on GPIO: 91
    wilc_sdio mmc0:0001:1 wlan0: INFO [wlan_initialize_threads]Initializing Threads ...
    wilc_sdio mmc0:0001:1 wlan0: INFO [wlan_initialize_threads]Creating kthread for
    transmission
    wilc_sdio mmc0:0001:1 wlan0: INFO [wlan_initialize_threads]Creating kthread for Debugging
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_wlan_get_firmware]Detect chip WILCSO2
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_wlan_get_firmware]loading firmware mchp/
    wilcso2_wifi_firmware.bin
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_wlan_get_firmware]WLAN firmware: mchp/
    wilcso2_wifi_firmware.bin
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_firmware_download]Downloading Firmware ...
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_wlan_firmware_download]Downloading firmware size =
    134964
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_firmware_download]Download Succeeded
    wilc_sdio mmc0:0001:1 wlan0: INFO [linux_wlan_start_firmware]Starting Firmware ...
    wilc_sdio mmc0:0001:1 wlan0: INFO [linux_wlan_start_firmware]Waiting for FW to get
    ready ...
    wilc_sdio mmc0:0001:1 wlan0: INFO [linux_wlan_start_firmware]Firmware successfully started
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_wlan_initialize]WILC Firmware Ver =
    WILCSO2_WIFI_FW_REL_2_00
    wilc_sdio mmc0:0001:1 wlan0: INFO [linux_wlan_init_test_config]Start configuring Firmware
    wilc_sdio mmc0:0001:1 wlan0: INFO [wilc_mac_open]Mac address: fa:f0:05:f1:3d:64
  3. To connect to the AP, perform the following steps:
    1. Connect to an unsecured AP using the following commands:
      # wpa_cli -p/var/run/wpa_supplicant ap_scan 1
      # wpa_cli -p/var/run/wpa_supplicant add_network
      # wpa_cli -p/var/run/wpa_supplicant set_network 0 ssid '"User_AP"'
      # wpa_cli -p/var/run/wpa_supplicant set_network 0 key_mgmt NONE
      # wpa_cli -p/var/run/wpa_supplicant select_network 0
      Note: The user must replace User_AP with the Service Set Identifier (SSID) of the desired AP.
    2. Connect to the WPA secured AP using the following commands to scan and connect to a WPA or WPA2, and Temporal Key Integrity Protocol (TKIP) or Advanced Encryption Standard (AES) protected AP.
      # wpa_cli -p/var/run/wpa_supplicant ap_scan 1
      # wpa_cli -p/var/run/wpa_supplicant add_network
      # wpa_cli -p/var/run/wpa_supplicant set_network 0 ssid ‘”User_AP”’
      # wpa_cli -p/var/run/wpa_supplicant set_network 0 key_mgmt WPA-PSK
      # wpa_cli -p/var/run/wpa_supplicant set_network 0 psk ‘”12345678”’
      # wpa_cli -p/var/run/wpa_supplicant select_network 0
      Note: The user must change User_AP and 12345678 with the SSID and password of the desired AP.
    3. Connect to the WPA2/WPA3 secured AP using the following commands to scan and connect to a WPA2 or WPA3 and Counter Mode CBC-MAC Protocol (CCMP) or AES protected AP.
      # wpa_cli -p/var/run/wpa_supplicant ap_scan 1
      # wpa_cli -p/var/run/wpa_supplicant add_network
      # wpa_cli -p/var/run/wpa_supplicant set_network 0 ssid ‘”User_AP”’
      # wpa_cli -i wlan0 set_network 0 ieee80211w 1
      # wpa_cli -i wlan0 set_network 0 key_mgmt SAE WPA-PSK WPA-PSK-SHA256
      # wpa_cli -i wlan0 set_network 0 pairwise CCMP
      # wpa_cli -i wlan0 set_network 0 group CCMP
      # wpa_cli -i wlan0 set_network 0 psk ‘”1234567811”’
      # wpa_cli -i wlan0 set_network 0 sae_password ‘”1234567890”’
      # wpa_cli -i wlan0 set_network 0 proto RSN
      # wpa_cli -i wlan0 select_network 0
      Note: The user must replace User_AP, 1234567811 and 1234567890 with the SSID, password and sae_password of the desired AP.
    4. Connect to the WPA3 (only) secured AP using the following commands to scan and connect to a WPA3 and CCMP or AES protected AP.
      # wpa_cli -p/var/run/wpa_supplicant ap_scan 1
      # wpa_cli -p/var/run/wpa_supplicant add_network
      # wpa_cli -p/var/run/wpa_supplicant set_network 0 ssid ‘”User_AP”’
      # wpa_cli -i wlan0 set_network 0 ieee80211w 1
      # wpa_cli -i wlan0 set_network 0 key_mgmt SAE
      # wpa_cli -i wlan0 set_network 0 pairwise CCMP
      # wpa_cli -i wlan0 set_network 0 group CCMP
      # wpa_cli -i wlan0 set_network 0 sae_password ‘”1234567890”’
      # wpa_cli -i wlan0 set_network 0 proto RSN
      # wpa_cli -i wlan0 select_network 0
      Note: The user must replace User_AP and 1234567890 with the SSID and sae_password of the desired AP.
    5. Connect to the WPS secured AP, trigger WPS Push-Button mode and scan to connect to a WPA3-protected AP using CCMP or AES protected AP using the following.

      wpa_cli wps_pbc

      (or) connect using PIN method, using the following command:

      sudo wpa_cli wps_pin any <the pin>
      Note: The user can replace <the pin> with the desired WPS pin.
  4. Run the DHCP service. If the IP address can be allocated from the AP automatically, start the DHCP client using the following command:
    #dhcpcd wlan0 &
    Note: If the AP does not support the DHCP service, manually set the static IP address value using the ifconfig wlan0 xxx,xxx.xxx.xxx command.
  5. Check and validate the connection status using the following commands:

    # wpa_cli status
    bssid=88:9b:39:f3:d0:4d
    ssid=User_AP
    id=0
    mode=station
    pairwise_cipher=NONE
    group_cipher=NONE
    key_mgmt=NONE
    wpa_state=COMPLETED
    ip_address=192.168.43.2
    address=00:80:c2:b3:d7:4d

The user can save and use the network information to automatically connect to the network using the wpa_cli save command in the Linux.