summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarcin Juszkiewicz <hrw@openembedded.org>2006-10-12 10:31:59 +0000
committerMarcin Juszkiewicz <hrw@openembedded.org>2006-10-12 10:31:59 +0000
commitbd83a5a85bc3de031783f587977d77fc9a596df4 (patch)
tree4db18fd10db72ca002dbc6c8c8ae6e1eb99ab5c6
parent90458249b3cabb3ff98d43fa724c62eae1acc0d6 (diff)
wpa-supplicant: added 0.4.8 from .oz354x
-rw-r--r--packages/wpa-supplicant/files/wpa-supplicant.sh85
-rw-r--r--packages/wpa-supplicant/wpa-gui_0.4.8.bb3
-rw-r--r--packages/wpa-supplicant/wpa-supplicant-0.4.8/.mtn2git_empty0
-rw-r--r--packages/wpa-supplicant/wpa-supplicant-0.4.8/defconfig160
-rw-r--r--packages/wpa-supplicant/wpa-supplicant-0.4.8/driver-hermes.patch889
-rw-r--r--packages/wpa-supplicant/wpa-supplicant-0.4.8/driver-zd1211.patch535
-rw-r--r--packages/wpa-supplicant/wpa-supplicant-0.4.8/madwifi-bsd-fix.diff12
-rw-r--r--packages/wpa-supplicant/wpa-supplicant-0.4.8/wpa_supplicant.conf502
-rw-r--r--packages/wpa-supplicant/wpa-supplicant_0.4.8.bb46
9 files changed, 2232 insertions, 0 deletions
diff --git a/packages/wpa-supplicant/files/wpa-supplicant.sh b/packages/wpa-supplicant/files/wpa-supplicant.sh
new file mode 100644
index 0000000000..5c9e5d33a7
--- /dev/null
+++ b/packages/wpa-supplicant/files/wpa-supplicant.sh
@@ -0,0 +1,85 @@
+#!/bin/sh
+
+
+WPA_SUP_BIN="/usr/sbin/wpa_supplicant"
+WPA_SUP_PNAME="wpa_supplicant"
+WPA_SUP_PIDFILE="/var/run/wpa_supplicant.$IFACE.pid"
+WPA_SUP_OPTIONS="-B -P $WPA_SUP_PIDFILE -i $IFACE"
+
+VERBOSITY=0
+
+
+if [ -s "$IF_WPA_CONF" ]; then
+ WPA_SUP_CONF="-c $IF_WPA_CONF"
+else
+ exit 0
+fi
+
+if [ ! -x "$WPA_SUP_BIN" ]; then
+
+ if [ "$VERBOSITY" = "1" ]; then
+ echo "$WPA_SUP_PNAME: binaries not executable or missing from $WPA_SUP_BIN"
+ fi
+
+ exit 1
+fi
+
+if [ "$MODE" = "start" ] ; then
+ # driver type of interface, defaults to wext when undefined
+ if [ -s "/etc/wpa_supplicant/driver.$IFACE" ]; then
+ IF_WPA_DRIVER=$(cat "/etc/wpa_supplicant/driver.$IFACE")
+ elif [ -z "$IF_WPA_DRIVER" ]; then
+
+ if [ "$VERBOSITY" = "1" ]; then
+ echo "$WPA_SUP_PNAME: wpa-driver not provided, using \"wext\""
+ fi
+
+ IF_WPA_DRIVER="wext"
+ fi
+
+ # if we have passed the criteria, start wpa_supplicant
+ if [ -n "$WPA_SUP_CONF" ]; then
+
+ if [ "$VERBOSITY" = "1" ]; then
+ echo "$WPA_SUP_PNAME: $WPA_SUP_BIN $WPA_SUP_OPTIONS $WPA_SUP_CONF -D $IF_WPA_DRIVER"
+ fi
+
+ start-stop-daemon --start --quiet \
+ --name $WPA_SUP_PNAME --startas $WPA_SUP_BIN --pidfile $WPA_SUP_PIDFILE \
+ -- $WPA_SUP_OPTIONS $WPA_SUP_CONF -D $IF_WPA_DRIVER
+ fi
+
+ # if the interface socket exists, then wpa_supplicant was invoked successfully
+ if [ -S "$WPA_COMMON_CTRL_IFACE/$IFACE" ]; then
+
+ if [ "$VERBOSITY" = "1" ]; then
+ echo "$WPA_SUP_PNAME: ctrl_interface socket located at $WPA_COMMON_CTRL_IFACE/$IFACE"
+ fi
+
+ exit 0
+
+ fi
+
+elif [ "$MODE" = "stop" ]; then
+
+ if [ -f "$WPA_SUP_PIDFILE" ]; then
+
+ if [ "$VERBOSITY" = "1" ]; then
+ echo "$WPA_SUP_PNAME: terminating $WPA_SUP_PNAME daemon"
+ fi
+
+ start-stop-daemon --stop --quiet \
+ --name $WPA_SUP_PNAME --pidfile $WPA_SUP_PIDFILE
+
+ if [ -S "$WPA_COMMON_CTRL_IFACE/$IFACE" ]; then
+ rm -f $WPA_COMMON_CTRL_IFACE/$IFACE
+ fi
+
+ if [ -f "$WPA_SUP_PIDFILE" ]; then
+ rm -f $WPA_SUP_PIDFILE
+ fi
+ fi
+
+fi
+
+exit 0
diff --git a/packages/wpa-supplicant/wpa-gui_0.4.8.bb b/packages/wpa-supplicant/wpa-gui_0.4.8.bb
index 686545a148..4678ba79a2 100644
--- a/packages/wpa-supplicant/wpa-gui_0.4.8.bb
+++ b/packages/wpa-supplicant/wpa-gui_0.4.8.bb
@@ -5,6 +5,7 @@ edit wpa_supplicant networks."
SECTION = "network"
LICENSE = "GPL BSD"
HOMEPAGE = "http://hostap.epitest.fi/wpa_supplicant/"
+RDEPENDS = "wpa-supplicant"
PR = "r1"
SRC_URI = "http://hostap.epitest.fi/releases/wpa_supplicant-${PV}.tar.gz "
@@ -13,6 +14,8 @@ S = "${WORKDIR}/wpa_supplicant-${PV}/wpa_gui/"
inherit qmake qt3x11
+EXTRA_QMAKEVARS_POST += "CONFIG+=thread"
+
do_install () {
install -d ${D}${sbindir}
install -m 755 wpa_gui ${D}${sbindir}
diff --git a/packages/wpa-supplicant/wpa-supplicant-0.4.8/.mtn2git_empty b/packages/wpa-supplicant/wpa-supplicant-0.4.8/.mtn2git_empty
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/packages/wpa-supplicant/wpa-supplicant-0.4.8/.mtn2git_empty
diff --git a/packages/wpa-supplicant/wpa-supplicant-0.4.8/defconfig b/packages/wpa-supplicant/wpa-supplicant-0.4.8/defconfig
new file mode 100644
index 0000000000..930ef04835
--- /dev/null
+++ b/packages/wpa-supplicant/wpa-supplicant-0.4.8/defconfig
@@ -0,0 +1,160 @@
+# This file lists the configuration options that are used when building the
+# hostapd binary. All lines starting with # are ignored. Configuration option
+# lines must be commented out complete, if they are not to be included, i.e.,
+# just setting VARIABLE=n is not disabling that variable.
+#
+# This file is included in Makefile, so variables like CFLAGS and LIBS can also
+# be modified from here. In most cass, these lines should use += in order not
+# to override previous values of the variables.
+
+CFLAGS = $(TARGET_CFLAGS) -I../hostapd -I../utils -I../driver/modules -Wall -MMD
+
+# for wpa_supplicant, wpa_cli
+LIBS = $(TARGET_LDFLAGS)
+
+# for wpa_passphrase:
+LIBS_p = $(TARGET_LDFLAGS)
+
+
+# Uncomment following two lines and fix the paths if you have installed openssl
+# in non-default location
+#CFLAGS += -I/usr/local/openssl/include
+#LIBS += -L/usr/local/openssl/lib
+
+# Example configuration for various cross-compilation platforms
+
+#### sveasoft (e.g., for Linksys WRT54G) ######################################
+#CC=mipsel-uclibc-gcc
+#CC=/opt/brcm/hndtools-mipsel-uclibc/bin/mipsel-uclibc-gcc
+#CFLAGS += -Os
+#CPPFLAGS += -I../src/include -I../../src/router/openssl/include
+#LIBS += -L/opt/brcm/hndtools-mipsel-uclibc-0.9.19/lib -lssl
+###############################################################################
+
+#### openwrt (e.g., for Linksys WRT54G) #######################################
+#CC=mipsel-uclibc-gcc
+#CC=/opt/brcm/hndtools-mipsel-uclibc/bin/mipsel-uclibc-gcc
+#CFLAGS += -Os
+#CPPFLAGS=-I../src/include -I../openssl-0.9.7d/include \
+# -I../WRT54GS/release/src/include
+#LIBS = -lssl
+###############################################################################
+
+
+# Driver interface for Host AP driver
+CONFIG_DRIVER_HOSTAP=y
+
+# Driver interface for Agere driver
+CONFIG_DRIVER_HERMES=y
+
+# Driver interface for madwifi driver
+#CONFIG_DRIVER_MADWIFI=y
+# Change include directories to match with the local setup
+#CFLAGS += -I../madwifi/wpa
+
+# Driver interface for Prism54 driver
+#CONFIG_DRIVER_PRISM54=y
+
+# Driver interface for ndiswrapper
+#CONFIG_DRIVER_NDISWRAPPER=y
+
+# Driver interface for Atmel driver
+#CONFIG_DRIVER_ATMEL=y
+
+# Driver interface for Broadcom driver
+#CONFIG_DRIVER_BROADCOM=y
+# Example path for wlioctl.h; change to match your configuration
+#CFLAGS += -I/opt/WRT54GS/release/src/include
+
+# Driver interface for Intel ipw2100 driver
+#CONFIG_DRIVER_IPW2100=y
+
+# Driver interface for the Zydas zd1211 driver
+CONFIG_DRIVER_ZD1211=y
+
+# Driver interface for generic Linux wireless extensions
+CONFIG_DRIVER_WEXT=y
+
+# Driver interface for FreeBSD net80211 layer (e.g., Atheros driver)
+#CONFIG_DRIVER_BSD=y
+#CFLAGS += -I/usr/local/include
+#LIBS += -L/usr/local/lib
+
+# Driver interface for Windows NDIS
+#CONFIG_DRIVER_NDIS=y
+#CFLAGS += -I/usr/include/w32api/ddk
+#LIBS += -L/usr/local/lib
+# For native build using mingw
+#CONFIG_NATIVE_WINDOWS=y
+# Additional directories for cross-compilation on Linux host for mingw target
+#CFLAGS += -I/opt/mingw/mingw32/include/ddk
+#LIBS += -L/opt/mingw/mingw32/lib
+#CC=mingw32-gcc
+
+# Driver interface for development testing
+#CONFIG_DRIVER_TEST=y
+
+# Enable IEEE 802.1X Supplicant (automatically included if any EAP method is
+# included)
+CONFIG_IEEE8021X_EAPOL=y
+
+# EAP-MD5 (automatically included if EAP-TTLS is enabled)
+CONFIG_EAP_MD5=y
+
+# EAP-MSCHAPv2 (automatically included if EAP-PEAP is enabled)
+CONFIG_EAP_MSCHAPV2=y
+
+# EAP-TLS
+CONFIG_EAP_TLS=y
+
+# EAL-PEAP
+CONFIG_EAP_PEAP=y
+
+# EAP-TTLS
+CONFIG_EAP_TTLS=y
+
+# EAP-GTC
+CONFIG_EAP_GTC=y
+
+# EAP-OTP
+CONFIG_EAP_OTP=y
+
+# EAP-SIM (enable CONFIG_PCSC, if EAP-SIM is used)
+#CONFIG_EAP_SIM=y
+
+# EAP-PSK (experimental; this is _not_ needed for WPA-PSK)
+#CONFIG_EAP_PSK=y
+
+# LEAP
+CONFIG_EAP_LEAP=y
+
+# EAP-AKA (enable CONFIG_PCSC, if EAP-AKA is used)
+#CONFIG_EAP_AKA=y
+
+# PKCS#12 (PFX) support (used to read private key and certificate file from
+# a file that usually has extension .p12 or .pfx)
+CONFIG_PKCS12=y
+
+# PC/SC interface for smartcards (USIM, GSM SIM)
+# Enable this if EAP-SIM or EAP-AKA is included
+#CONFIG_PCSC=y
+
+# Development testing
+#CONFIG_EAPOL_TEST=y
+
+# Replace native Linux implementation of packet sockets with libdnet/libpcap.
+# This will be automatically set for non-Linux OS.
+#CONFIG_DNET_PCAP=y
+
+# Include control interface for external programs, e.g, wpa_cli
+CONFIG_CTRL_IFACE=y
+
+# Include interface for using external supplicant (Xsupplicant) for EAP
+# authentication
+#CONFIG_XSUPPLICANT_IFACE=y
+
+# Include support for GNU Readline and History Libraries in wpa_cli.
+# When building a wpa_cli binary for distribution, please note that these
+# libraries are licensed under GPL and as such, BSD license may not apply for
+# the resulting binary.
+#CONFIG_READLINE=y
diff --git a/packages/wpa-supplicant/wpa-supplicant-0.4.8/driver-hermes.patch b/packages/wpa-supplicant/wpa-supplicant-0.4.8/driver-hermes.patch
new file mode 100644
index 0000000000..0bf82489ec
--- /dev/null
+++ b/packages/wpa-supplicant/wpa-supplicant-0.4.8/driver-hermes.patch
@@ -0,0 +1,889 @@
+
+#
+# Patch managed by http://www.holgerschurig.de/patcher.html
+#
+
+--- /dev/null
++++ wpa_supplicant/driver_hermes.c
+@@ -0,0 +1,705 @@
++/*
++ * WPA Supplicant - testing driver interface
++ * Copyright (c) 2004-2005, Jouni Malinen <jkmaline@cc.hut.fi>
++ *
++ * This program is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License version 2 as
++ * published by the Free Software Foundation.
++ *
++ * Alternatively, this software may be distributed under the terms of BSD
++ * license.
++ *
++ * See README and COPYING for more details.
++ */
++
++#include <stdlib.h>
++#include <stdio.h>
++#include <unistd.h>
++#include <string.h>
++#include <sys/ioctl.h>
++#include <errno.h>
++#include <net/if_arp.h>
++
++#include "wireless_copy.h"
++#include "common.h"
++#include "driver.h"
++
++#include "eloop.h"
++#include "wpa_supplicant.h"
++#include "priv_netlink.h"
++
++#include "driver_wext.h"
++#include "driver_hermes.h"
++
++#define MAC2STR(a) (a)[0], (a)[1], (a)[2], (a)[3], (a)[4], (a)[5]
++#define MACSTR "%02x:%02x:%02x:%02x:%02x:%02x"
++
++/* Enumeration for supported Hermes Types */
++enum
++{
++ WL_HERMES_UNKNOWN = 0,
++ WL_HERMES_1 = 1,
++ WL_HERMES_2 = 2,
++ WL_HERMES_25 = 3
++};
++
++
++
++
++struct wpa_driver_hermes_data {
++ void *wext; /* private data for driver_wext */
++ void *ctx;
++ char ifname[IFNAMSIZ + 1];
++ int sock;
++ int type;
++};
++
++
++
++/****************************************************************************/
++/* */
++/* Routines for basic device access to Agere Hermes-I/Hermes-II via the UIL */
++/* */
++/****************************************************************************/
++
++IFBP _connect(void *priv)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ int result = 0;
++ IFBP ifbp = NULL;
++ struct uilreq urq;
++
++ //wpa_printf(MSG_DEBUG, "%s: %s %d", __FUNCTION__, drv->ifname, drv->sock);
++
++ memset(&urq, 0, sizeof(urq));
++
++ strcpy(urq.ifr_name, drv->ifname);
++ urq.command = UIL_FUN_CONNECT;
++
++ result = ioctl(drv->sock, WVLAN2_IOCTL_UIL, &urq);
++ if (result == 0 && urq.result == UIL_SUCCESS) {
++ ifbp = urq.hcfCtx;
++ } else {
++ wpa_printf(MSG_DEBUG, "%s: could not set IFBP, result %d", __FUNCTION__, result);
++ }
++
++ return ifbp;
++}
++
++
++void _disconnect(void *priv, IFBP ifbp)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ int result = 0;
++ struct uilreq urq;
++
++ //wpa_printf(MSG_DEBUG, "%s: %s", __FUNCTION__, drv->ifname);
++
++ if (ifbp != NULL) {
++ memset(&urq, 0, sizeof(struct uilreq));
++
++ strcpy(urq.ifr_name, drv->ifname);
++ urq.command = UIL_FUN_DISCONNECT;
++ urq.hcfCtx = ifbp;
++
++ result = ioctl(drv->sock, WVLAN2_IOCTL_UIL, &urq);
++
++ if (result != 0 || urq.result != UIL_SUCCESS) {
++ wpa_printf( MSG_WARNING, "wl_disconnect(): ioctl() failed, errno: %d", errno );
++ wpa_printf( MSG_WARNING, "wl_disconnect(): urq.result: %d", urq.result );
++ }
++ } else {
++ wpa_printf(MSG_WARNING, "wl_disconnect(): called with NULL ifbp");
++ }
++
++ return;
++}
++
++int _get_info(void *priv, ltv_t *ltv)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ int result = 0;
++ IFBP ifbp = NULL;
++ struct uilreq urq;
++
++ //wpa_printf(MSG_DEBUG, "%s: %s", __FUNCTION__, drv->ifname);
++
++ /* First, connect to the device */
++ ifbp = _connect(priv);
++ if (ifbp != NULL && ltv != NULL) {
++ memset(&urq, 0, sizeof(struct uilreq));
++
++ strcpy(urq.ifr_name, drv->ifname);
++ urq.hcfCtx = ifbp;
++ urq.command = UIL_FUN_GET_INFO;
++ urq.len = sizeof(ltv_t);
++ urq.data = ltv;
++
++ result = ioctl(drv->sock, WVLAN2_IOCTL_UIL, &urq);
++
++ if (result != 0 || urq.result != UIL_SUCCESS) {
++ wpa_printf(MSG_WARNING, "wl_disconnect(): ioctl() failed, errno: %d", errno);
++ wpa_printf(MSG_WARNING, "wl_disconnect(): urq.result: %d", urq.result);
++ }
++ _disconnect(priv, ifbp);
++ } else {
++ wpa_printf( MSG_WARNING, "Could not connect to the device, or LTV NULL");
++ result = -1;
++ }
++
++ return result;
++}
++
++int _put_info(void *priv, ltv_t *ltv)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ int result = 0;
++ IFBP ifbp = NULL;
++ struct uilreq urq;
++
++ //wpa_printf(MSG_DEBUG, "%s: %s", __FUNCTION__, drv->ifname);
++
++ /* First, connect to the device */
++ ifbp = _connect(priv);
++ if (ifbp != NULL && ltv != NULL) {
++ memset(&urq, 0, sizeof(struct uilreq));
++
++ strcpy(urq.ifr_name, drv->ifname);
++ urq.hcfCtx = ifbp;
++ urq.command = UIL_FUN_PUT_INFO;
++ urq.len = sizeof( ltv_t );
++ urq.data = ltv;
++
++ result = ioctl(drv->sock, WVLAN2_IOCTL_UIL, &urq);
++
++ if (result != 0 || urq.result != UIL_SUCCESS) {
++ wpa_printf(MSG_WARNING, "_put_info(): ioctl() failed, errno: %d", errno);
++ wpa_printf(MSG_WARNING, "_put_info(): urq.result: %d", urq.result);
++ }
++
++ _disconnect(priv, ifbp);
++ } else {
++ wpa_printf(MSG_WARNING, "%s: could not connect to the device, or LTV NULL", __FUNCTION__ );
++ result = -1;
++ }
++
++ return result;
++}
++
++
++static void _detect_hermes_type(void *priv)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ CFG_FW_IDENTITY_STRCT *fw_id;
++ ltv_t ltv;
++ int result;
++
++ //wpa_printf(MSG_DEBUG, "%s", __FUNCTION__);
++
++ drv->type = WL_HERMES_UNKNOWN;
++
++ if (drv->sock >= 0) {
++ fw_id = (CFG_FW_IDENTITY_STRCT *)&ltv;
++ fw_id->len = ( sizeof(CFG_FW_IDENTITY_STRCT) / sizeof( hcf_16 )) - 1;
++ fw_id->typ = CFG_FW_IDENTITY;
++
++ result = _get_info(priv, (ltv_t *)fw_id);
++ if (result == HCF_SUCCESS) {
++ //wpa_printf(MSG_DEBUG, "PRI CompID : %d", fw_id->comp_id);
++ //wpa_printf(MSG_DEBUG, "PRI Variant : %d", fw_id->variant);
++ //wpa_printf(MSG_DEBUG, "PRI Version : %d.%02d", fw_id->version_major, fw_id->version_minor);
++
++ switch(fw_id->comp_id) {
++ case COMP_ID_FW_STA:
++ switch (fw_id->variant) {
++ case 1:
++ case 2:
++ wpa_printf(MSG_DEBUG, "found Hermes 1 STA");
++ drv->type = WL_HERMES_1;
++ break;
++
++ case 3:
++ wpa_printf(MSG_DEBUG, "found Hermes 2 STA");
++ drv->type = WL_HERMES_2;
++ break;
++ case 4:
++ wpa_printf(MSG_DEBUG, "found Hermes 2.5 STA");
++ drv->type = WL_HERMES_25;
++ break;
++ }
++ break;
++
++ case COMP_ID_FW_AP:
++ switch (fw_id->variant) {
++ case 1:
++ wpa_printf(MSG_DEBUG, "found Hermes 1 AP");
++ drv->type = WL_HERMES_1;
++ break;
++
++ case 2:
++ wpa_printf(MSG_DEBUG, "found Hermes 2 AP" );
++ drv->type = WL_HERMES_2;
++ break;
++ }
++ break;
++
++ default:
++ wpa_printf(MSG_WARNING, "could not detect Hermes type!");
++ break;
++ }
++ }
++ }
++}
++
++
++
++/****************************************************************************/
++
++
++static int wpa_driver_hermes_set_wpa_ie(void *priv, const char *wpa_ie,
++ size_t wpa_ie_len)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ ltv_t ltv;
++
++ wpa_printf(MSG_DEBUG, "%s", __FUNCTION__);
++
++ ltv.len = 2;
++ ltv.typ = CFG_SET_WPA_AUTH_KEY_MGMT_SUITE;
++
++ switch(drv->type) {
++ case WL_HERMES_1:
++ ltv.u.u16[0] = 2;
++ break;
++
++ case WL_HERMES_2:
++ case WL_HERMES_25:
++ ltv.u.u16[0] = 4;
++ break;
++
++ default:
++ ltv.u.u16[0] = 0;
++ break;
++ }
++
++ return _put_info(priv, &ltv);
++}
++
++
++static int wpa_driver_hermes_set_wpa(void *priv, int enabled)
++{
++ ltv_t ltv;
++
++ wpa_printf(MSG_DEBUG, "%s: enabled=%d", __func__, enabled);
++
++ ltv.len = 2;
++ ltv.typ = CFG_CNF_ENCRYPTION;
++ ltv.u.u16[0] = enabled ? 2 : 0; /* Setting CFG_CNF_ENCRYPTION to 2 sets WPA: TKIP or better */
++
++ return _put_info(priv, &ltv);
++}
++
++
++static int wpa_driver_hermes_set_key(void *priv, wpa_alg alg,
++ const u8 *addr, int key_idx,
++ int set_tx, const u8 *seq, size_t seq_len,
++ const u8 *key, size_t key_len)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ int ret = 0;
++ char *alg_name;
++ ltv_t ltv;
++ int count = 0;
++ int buf_idx = 0;
++ hcf_8 tsc[] = { 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00 };
++ hcf_8 rsc[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
++
++
++ switch (alg) {
++ case WPA_ALG_NONE:
++ alg_name = "none";
++ break;
++ case WPA_ALG_WEP:
++ alg_name = "WEP";
++ break;
++ case WPA_ALG_TKIP:
++ alg_name = "TKIP";
++ break;
++ case WPA_ALG_CCMP:
++ alg_name = "CCMP";
++ break;
++ default:
++ return -1;
++ }
++
++ wpa_printf(MSG_DEBUG, "%s: alg=%s key_idx=%d set_tx=%d seq_len=%d "
++ "key_len=%d", __FUNCTION__, alg_name, key_idx, set_tx,
++ seq_len, key_len);
++
++ if (seq_len > IW_ENCODE_SEQ_MAX_SIZE) {
++ wpa_printf(MSG_DEBUG, "%s: Invalid seq_len %lu", __FUNCTION__, (unsigned long) seq_len);
++ return -2;
++ }
++
++ /* Check the key index here; if 0, load as Pairwise Key, otherwise, load as
++ a group key. Note that for the Hermes, the RIDs for group/pairwise keys
++ are different from each other and different than the default WEP keys as
++ well. */
++ switch (alg) {
++ case WPA_ALG_TKIP:
++ /* Make sure that there is no data queued up in the firmware before
++ setting the TKIP keys. If this check is not performed, some data
++ may be sent out with incorrect MIC and cause synchronizarion
++ errors with the AP */
++ /* Check every 1ms for 100ms */
++ for (count = 0; count < 100; count++) {
++ usleep(1000);
++
++ ltv.len = 2;
++ ltv.typ = 0xFD91; // This RID not defined in HCF yet!!!
++ ltv.u.u16[0] = 0;
++
++ _get_info( priv, &ltv);
++
++ if (ltv.u.u16[0] == 0)
++ break;
++ }
++
++ if (count == 100)
++ wpa_printf(MSG_DEBUG, "%s: Timed out waiting for TxQ!", __FUNCTION__);
++
++
++ switch (key_idx) {
++ case 0:
++ /* Only load key as pairwise key for Hermes-II and II.5. For Hermes-I,
++ fall through to the next case and load the pairwise key as
++ a Group Key at index 0. */
++ if (drv->type == WL_HERMES_2 || drv->type == WL_HERMES_25) {
++ ltv.len = 28;
++ ltv.typ = CFG_ADD_TKIP_MAPPED_KEY;
++
++ /* Load the BSSID */
++ memcpy(&ltv.u.u8[buf_idx], addr, ETH_ALEN);
++ buf_idx += ETH_ALEN;
++
++ /* Load the TKIP key */
++ memcpy(&ltv.u.u8[buf_idx], &key[0], 16);
++ buf_idx += 16;
++
++ /* Load the TSC */
++ memcpy(&ltv.u.u8[buf_idx], tsc, 8);
++ buf_idx += 8;
++
++ /* Load the RSC */
++ /* Copy the RSC from the supplicant to a local buffer, because
++ the RSC doesn't always contain the padding needed */
++ memcpy(rsc, seq, seq_len);
++ memcpy(&ltv.u.u8[buf_idx], rsc, 8);
++ buf_idx += 8;
++
++ /* Load the TxMIC key */
++ memcpy(&ltv.u.u8[buf_idx], &key[16], 8);
++ buf_idx += 8;
++
++ /* Load the RxMIC key */
++ memcpy(&ltv.u.u8[buf_idx], &key[24], 8);
++
++ /* Send the request to the Hermes */
++ _put_info(priv, &ltv);
++ break;
++ }
++
++ case 1:
++ case 2:
++ case 3:
++ ltv.len = 26;
++ ltv.typ = CFG_ADD_TKIP_DEFAULT_KEY;
++
++ /* Load the key Index */
++ ltv.u.u16[buf_idx] = key_idx;
++
++ /* If this is a Tx Key, set bit 8000 */
++ if (set_tx)
++ ltv.u.u16[buf_idx] |= 0x8000;
++
++ buf_idx += 2;
++
++ /* Load the RSC */
++ /* Copy the RSC from the supplicant to a local buffer, because
++ the RSC doesn't always contain the padding needed */
++ memcpy(rsc, seq, seq_len);
++ memcpy(&ltv.u.u8[buf_idx], rsc, 8);
++ buf_idx += 8;
++
++ /* Load the TKIP, TxMIC, and RxMIC keys in one shot, because in
++ CFG_ADD_TKIP_DEFAULT_KEY they are back-to-back */
++ memcpy(&ltv.u.u8[buf_idx], key, key_len);
++ buf_idx += key_len;
++
++ /* Load the TSC */
++ memcpy(&ltv.u.u8[buf_idx], tsc, 8);
++
++ /* Send the request to the Hermes */
++ _put_info(priv, &ltv);
++ break;
++
++ default:
++ break;
++ }
++
++ break;
++
++ case WPA_ALG_WEP:
++ case WPA_ALG_CCMP:
++ break;
++
++ case WPA_ALG_NONE:
++ switch (key_idx) {
++ case 0:
++ if (drv->type == WL_HERMES_2 || drv->type == WL_HERMES_25) {
++ /* Only clear a pairwise key for Hermes-II. For Hermes-I,
++ fall through to the next case and clear the key as a
++ Group Key at index 0. */
++ if (addr) {
++ ltv.len = 7;
++ ltv.typ = CFG_REMOVE_TKIP_MAPPED_KEY;
++
++ memcpy(&ltv.u.u8[0], addr, ETH_ALEN);
++
++ _put_info(priv, &ltv);
++ }
++ break;
++ }
++
++ case 1:
++ case 2:
++ case 3:
++ /* Clear the Group TKIP keys by index */
++ ltv.len = 2;
++ ltv.typ = CFG_REMOVE_TKIP_DEFAULT_KEY;
++
++ ltv.u.u16[0] = key_idx;
++
++ _put_info(priv, &ltv);
++ break;
++
++ default:
++ break;
++ }
++ break;
++
++ default:
++ break;
++ }
++
++ return ret;
++}
++
++
++static int wpa_driver_hermes_set_countermeasures(void *priv, int enabled)
++{
++ ltv_t ltv;
++
++ /* The supplicant handles all the timers related to MIC failure and
++ countermeasures. When countermeasures are enabled, shut down the card;
++ when disable, re-enable the card. Make sure that the EAPOL message
++ is getting out before card disable */
++
++ wpa_printf(MSG_DEBUG, "%s: enabled=%d", __FUNCTION__, enabled);
++
++ ltv.len = 2;
++ ltv.typ = CFG_DRIVER_ENABLE;
++ ltv.u.u16[0] = enabled ? 0 : 1;
++
++ return _put_info(priv, &ltv);
++}
++
++
++static int wpa_driver_hermes_set_drop_unencrypted(void *priv, int enabled)
++{
++ ltv_t ltv;
++
++ wpa_printf(MSG_DEBUG, "%s: enabled=%d", __FUNCTION__, enabled);
++
++ ltv.len = 2;
++ ltv.typ = CFG_CNF_EXCL_UNENCRYPTED;
++ ltv.u.u16[0] = enabled;
++
++ return _put_info(priv, &ltv);
++}
++
++
++static int wpa_driver_hermes_deauthenticate(void *priv, const u8 *addr,
++ int reason_code)
++{
++ wpa_printf(MSG_DEBUG, "%s: *DUMMY* %d", __FUNCTION__, reason_code);
++
++ return 0;
++}
++
++
++static int wpa_driver_hermes_disassociate(void *priv, const u8 *addr, int reason_code)
++{
++ ltv_t ltv;
++
++ wpa_printf(MSG_DEBUG, "%s: reason=%d", __FUNCTION__, reason_code);
++
++ ltv.len = 2;
++ ltv.typ = 0xFCC8; // This RID not defined in HCF yet!!!
++ memcpy( &ltv.u.u8[0], addr, ETH_ALEN );
++ ltv.u.u16[ETH_ALEN / 2] = reason_code;
++
++ return _put_info( priv, &ltv);
++}
++
++
++static int wpa_driver_hermes_associate(
++ void *priv, struct wpa_driver_associate_params *params)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++
++#if 0
++ wpa_printf(MSG_DEBUG, "%s", __FUNCTION__);
++#else
++ wpa_printf(MSG_DEBUG, "%s: priv=%p freq=%d pairwise_suite=%d "
++ "group_suite=%d key_mgmt_suite=%d auth_alg=%d mode=%d",
++ __func__, priv, params->freq, params->pairwise_suite,
++ params->group_suite, params->key_mgmt_suite,
++ params->auth_alg, params->mode);
++ if (params->bssid) {
++ wpa_printf(MSG_DEBUG, " bssid=" MACSTR,
++ MAC2STR(params->bssid));
++ }
++ if (params->ssid) {
++ wpa_hexdump_ascii(MSG_DEBUG, " ssid",
++ params->ssid, params->ssid_len);
++ }
++ if (params->wpa_ie) {
++ wpa_hexdump(MSG_DEBUG, " wpa_ie",
++ params->wpa_ie, params->wpa_ie_len);
++ }
++#endif
++
++ if (wpa_driver_hermes_set_wpa_ie(priv, params->wpa_ie, params->wpa_ie_len) < 0)
++ return -1;
++ if (wpa_driver_wext_set_freq(drv->wext, params->freq) < 0)
++ return -1;
++ if (wpa_driver_wext_set_ssid(drv->wext, params->ssid, params->ssid_len) < 0)
++ return -1;
++#ifdef UNSUPPORTED_IN_HERMES_DRIVER
++ if (wpa_driver_wext_hermes_bssid(drv->wext, params->bssid) < 0)
++ return -1;
++#endif
++
++ return 0;
++}
++
++
++static int wpa_driver_hermes_get_bssid(void *priv, u8 *bssid)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ return wpa_driver_wext_get_bssid(drv->wext, bssid);
++}
++
++
++static int wpa_driver_hermes_get_ssid(void *priv, u8 *ssid)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ return wpa_driver_wext_get_ssid(drv->wext, ssid);
++}
++
++
++static int wpa_driver_hermes_scan(void *priv, const u8 *ssid, size_t ssid_len)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ return wpa_driver_wext_scan(drv->wext, ssid, ssid_len);
++}
++
++
++static int wpa_driver_hermes_get_scan_results(void *priv,
++ struct wpa_scan_result *results,
++ size_t max_size)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ return wpa_driver_wext_get_scan_results(drv->wext, results, max_size);
++}
++
++
++static void * wpa_driver_hermes_init(void *ctx, const char *ifname)
++{
++ struct wpa_driver_hermes_data *drv;
++
++ wpa_printf(MSG_DEBUG, "%s: %s", __FUNCTION__, ifname);
++
++ drv = malloc(sizeof(*drv));
++ if (drv == NULL)
++ return NULL;
++ memset(drv, 0, sizeof(*drv));
++
++ /* Initialize wireless context */
++ drv->wext = wpa_driver_wext_init(ctx, ifname);
++ if (drv->wext == NULL) {
++ perror("no wext context");
++ goto no_wext;
++ }
++
++ drv->ctx = ctx;
++ strncpy(drv->ifname, ifname, sizeof(drv->ifname));
++
++ drv->sock = socket(PF_INET, SOCK_DGRAM, 0);
++ if (drv->sock < 0) {
++ perror("socket(PF_INET,SOCK_DGRAM)");
++ goto no_sock;
++ }
++
++ _detect_hermes_type(drv);
++
++ return drv;
++
++no_sock:
++ wpa_driver_wext_deinit(drv->wext);
++no_wext:
++ free(drv);
++ return NULL;
++}
++
++
++static void wpa_driver_hermes_deinit(void *priv)
++{
++ struct wpa_driver_hermes_data *drv = priv;
++ wpa_driver_wext_deinit(drv->wext);
++ close(drv->sock);
++ free(drv);
++}
++
++
++
++
++struct wpa_driver_ops wpa_driver_hermes_ops = {
++ .name = "hermes",
++ .desc = "wpa_supplicant hermes driver",
++
++ .init = wpa_driver_hermes_init,
++ .deinit = wpa_driver_hermes_deinit,
++
++ // from old driver_hermes.c:
++ .get_bssid = wpa_driver_hermes_get_bssid,
++ .get_ssid = wpa_driver_hermes_get_ssid,
++ .set_wpa = wpa_driver_hermes_set_wpa,
++ .set_key = wpa_driver_hermes_set_key,
++ //.events_init = wpa_driver_wext_events_init,
++ //.events_deinit = wpa_driver_wext_events_deinit,
++ .set_countermeasures = wpa_driver_hermes_set_countermeasures,
++ .set_drop_unencrypted = wpa_driver_hermes_set_drop_unencrypted,
++ .scan = wpa_driver_hermes_scan,
++ .get_scan_results = wpa_driver_hermes_get_scan_results,
++ .deauthenticate = wpa_driver_hermes_deauthenticate,
++ .disassociate = wpa_driver_hermes_disassociate,
++ .associate = wpa_driver_hermes_associate,
++
++
++#if 0
++ /* Not possible with current Hermes driver:
++ .set_auth_alg = wpa_driver_hermes_set_auth_alg, */
++#endif
++};
+--- /dev/null
++++ wpa_supplicant/driver_hermes.h
+@@ -0,0 +1,173 @@
++#ifndef HERMES_DRIVER_H
++#define HERMES_DRIVER_H
++
++typedef unsigned char hcf_8;
++typedef unsigned short hcf_16;
++typedef unsigned long hcf_32;
++typedef hcf_16 hcf_io;
++typedef hcf_8 *wci_bufp;
++
++typedef struct {
++ hcf_16 len;
++ hcf_16 typ;
++ unsigned short * bufp;
++} RID_LOG_STRCT;
++typedef RID_LOG_STRCT *RID_LOGP;
++
++typedef struct {
++ hcf_16 len;
++ hcf_16 typ;
++ hcf_16 comp_id;
++ hcf_16 variant;
++ hcf_16 version_major;
++ hcf_16 version_minor;
++} CFG_FW_IDENTITY_STRCT;
++
++typedef struct {
++ hcf_32 TxUnicastFrames;
++ hcf_32 TxMulticastFrames;
++ hcf_32 TxFragments;
++ hcf_32 TxUnicastOctets;
++ hcf_32 TxMulticastOctets;
++ hcf_32 TxDeferredTransmissions;
++ hcf_32 TxSingleRetryFrames;
++ hcf_32 TxMultipleRetryFrames;
++ hcf_32 TxRetryLimitExceeded;
++ hcf_32 TxDiscards;
++ hcf_32 RxUnicastFrames;
++ hcf_32 RxMulticastFrames;
++ hcf_32 RxFragments;
++ hcf_32 RxUnicastOctets;
++ hcf_32 RxMulticastOctets;
++ hcf_32 RxFCSErrors;
++ hcf_32 RxDiscardsNoBuffer;
++ hcf_32 TxDiscardsWrongSA;
++ hcf_32 RxWEPUndecryptable;
++ hcf_32 RxMsgInMsgFragments;
++ hcf_32 RxMsgInBadMsgFragments;
++ hcf_32 RxDiscardsWEPICVError;
++ hcf_32 RxDiscardsWEPExcluded;
++} CFG_HERMES_TALLIES_STRCT;
++
++typedef struct {