68c0bdff7a
WLAN driver for cards using the HERMES II and HERMES II.5 chipset Based on Agere Systems Linux LKM Wireless Driver Source Code, Version 7.22; complies with Open Source BSD License. The software is a modified version of wl_lkm_722_abg.tar.gz from the Agere Systems website, addapted for Ubuntu 9.04 and modified to fit in the current Linux kernel (2.6.31). Modified for kernel 2.6 by Henk de Groot <pe1dnn@amsat.org> Based on 7.18 version by Andrey Borzenkov <arvidjaar@mail.ru> $Revision: 39 $ Signed-off-by: Henk de Groot <pe1dnn@amsat.org> Cc: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
227 lines
8.2 KiB
C
227 lines
8.2 KiB
C
|
|
// vim:tw=110:ts=4:
|
|
#ifndef DHF_H
|
|
#define DHF_H
|
|
|
|
/**************************************************************************************************************
|
|
*
|
|
* FILE : DHF.H
|
|
*
|
|
* DATE : $Date: 2004/07/19 08:16:14 $ $Revision: 1.2 $
|
|
* Original : 2004/05/17 07:33:13 Revision: 1.25 Tag: hcf7_t20040602_01
|
|
* Original : 2004/05/11 06:03:14 Revision: 1.24 Tag: hcf7_t7_20040513_01
|
|
* Original : 2004/04/15 09:24:42 Revision: 1.22 Tag: hcf7_t7_20040415_01
|
|
* Original : 2004/04/09 14:35:52 Revision: 1.21 Tag: t7_20040413_01
|
|
* Original : 2004/04/01 15:32:55 Revision: 1.18 Tag: t7_20040401_01
|
|
* Original : 2004/03/10 15:39:28 Revision: 1.15 Tag: t20040310_01
|
|
* Original : 2004/03/04 11:03:38 Revision: 1.13 Tag: t20040304_01
|
|
* Original : 2004/02/25 14:14:37 Revision: 1.11 Tag: t20040302_03
|
|
* Original : 2004/02/24 13:00:28 Revision: 1.10 Tag: t20040224_01
|
|
* Original : 2004/02/19 10:57:28 Revision: 1.8 Tag: t20040219_01
|
|
*
|
|
* AUTHOR : John Meertens
|
|
* Nico Valster
|
|
*
|
|
* SPECIFICATION: .........
|
|
*
|
|
* DESC : structure definitions and function prototypes for unit DHF.
|
|
*
|
|
* Customizable via HCFCFG.H, which is included indirectly via HCF.H
|
|
*
|
|
***************************************************************************************************************
|
|
*
|
|
*
|
|
* SOFTWARE LICENSE
|
|
*
|
|
* This software is provided subject to the following terms and conditions,
|
|
* which you should read carefully before using the software. Using this
|
|
* software indicates your acceptance of these terms and conditions. If you do
|
|
* not agree with these terms and conditions, do not use the software.
|
|
*
|
|
* COPYRIGHT © 1994 - 1995 by AT&T. All Rights Reserved
|
|
* COPYRIGHT © 1999 - 2000 by Lucent Technologies. All Rights Reserved
|
|
* COPYRIGHT © 2001 - 2004 by Agere Systems Inc. All Rights Reserved
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source or binary forms, with or without
|
|
* modifications, are permitted provided that the following conditions are met:
|
|
*
|
|
* . Redistributions of source code must retain the above copyright notice, this
|
|
* list of conditions and the following Disclaimer as comments in the code as
|
|
* well as in the documentation and/or other materials provided with the
|
|
* distribution.
|
|
*
|
|
* . Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following Disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
*
|
|
* . Neither the name of Agere Systems Inc. nor the names of the contributors
|
|
* may be used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* Disclaimer
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
* INCLUDING, BUT NOT LIMITED TO, INFRINGEMENT AND THE IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. ANY
|
|
* USE, MODIFICATION OR DISTRIBUTION OF THIS SOFTWARE IS SOLELY AT THE USERS OWN
|
|
* RISK. IN NO EVENT SHALL AGERE SYSTEMS INC. OR CONTRIBUTORS BE LIABLE FOR ANY
|
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
* ON ANY THEORY OF LIABILITY, INCLUDING, BUT NOT LIMITED TO, CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
|
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
|
|
* DAMAGE.
|
|
*
|
|
*
|
|
**************************************************************************************************************/
|
|
|
|
|
|
#ifdef _WIN32_WCE
|
|
#include <windef.h>
|
|
#endif
|
|
|
|
#include "hcf.h" // includes HCFCFG.H too
|
|
|
|
#ifdef DHF_UIL
|
|
#define GET_INFO( pp ) uil_get_info( (LTVP)pp )
|
|
#define PUT_INFO( pp ) uil_put_info( (LTVP)pp )
|
|
#else
|
|
#define GET_INFO( pp ) hcf_get_info( ifbp, (LTVP)pp )
|
|
#define PUT_INFO( pp ) hcf_put_info( ifbp, (LTVP)pp )
|
|
#endif
|
|
|
|
|
|
/*---- Defines --------------------------------------------------------------*/
|
|
#define CODEMASK 0x0000FFFFL // Codemask for plug records
|
|
|
|
/*---- Error numbers --------------------------------------------------------*/
|
|
|
|
#define DHF_ERR_INCOMP_FW 0x40 //Image not compatible with NIC
|
|
|
|
/*---- Type definitions -----------------------------------------------------*/
|
|
//* needed by dhf_wrap.c
|
|
//
|
|
typedef struct {
|
|
LTVP ltvp;
|
|
hcf_16 len;
|
|
} LTV_INFO_STRUCT , *LTV_INFO_STRUCT_PTR;
|
|
|
|
|
|
/*
|
|
* Type: plugrecord
|
|
*
|
|
* Abstract: This structure represents a Plug Data Record.
|
|
*
|
|
* Description:
|
|
* This structure is used to overlay the plug records in the firmware memory image.
|
|
*/
|
|
|
|
typedef struct {
|
|
hcf_32 code; // Code to plug
|
|
hcf_32 addr; // Address within the memory image to plug it in
|
|
hcf_32 len; // The # of bytes which are available to store it
|
|
} plugrecord;
|
|
|
|
/*
|
|
* Type: stringrecord
|
|
*
|
|
* Abstract: This structure represents a Firmware debug/assert string
|
|
*
|
|
* Description:
|
|
* This structure is used to get assert and debug outputs in the driver and/or utility to be
|
|
* able to get more visability of the FW.
|
|
*/
|
|
|
|
#define MAX_DEBUGSTRINGS 1024
|
|
#define MAX_DEBUGSTRING_LEN 82
|
|
|
|
typedef struct {
|
|
hcf_32 id;
|
|
char str[MAX_DEBUGSTRING_LEN];
|
|
} stringrecord;
|
|
|
|
/*
|
|
* Type: exportrecord
|
|
*
|
|
* Abstract: This structure represents a Firmware export of a variable
|
|
*
|
|
* Description:
|
|
* This structure is used to get the address and name of a FW variable.
|
|
*/
|
|
|
|
#define MAX_DEBUGEXPORTS 2048
|
|
#define MAX_DEBUGEXPORT_LEN 12
|
|
|
|
typedef struct {
|
|
hcf_32 id;
|
|
char str[MAX_DEBUGEXPORT_LEN];
|
|
} exportrecord;
|
|
|
|
// Offsets in memimage array p[]
|
|
#define FWSTRINGS_FUNCTION 0
|
|
#define FWEXPORTS_FUNCTION 1
|
|
|
|
/*
|
|
* Type: memimage
|
|
*
|
|
* Abstract: The "root" description of a complete memory image
|
|
*
|
|
* Description:
|
|
* This type represents an entire memory image. The image is built up of several
|
|
* segments. These segments need not be contiguous areas in memory, in other words
|
|
* the image may contain 'holes'.
|
|
*
|
|
* The 'codep' field points to an array of segment_descriptor structures.
|
|
* The end of the array is indicated by a segment_descriptor of which all fields are zero.
|
|
* The 'execution' field is a 32-bit address representing the execution address
|
|
* of the firmware within the memory image. This address is zero in case of non-volatile
|
|
* memory download.
|
|
* The 'compat' field points to an array of TODO
|
|
* The end of the array is indicated by a plug record of which all fields are zero.
|
|
* The 'identity' field points to an array of TODO
|
|
* The end of the array is indicated by a plug record of which all fields are zero.
|
|
* The Hermes-I specific 'pdaplug' field points to an array of Production Data Plug record structures.
|
|
* The end of the array is indicated by a plug record of which all fields are zero.
|
|
* The Hermes-I specific 'priplug' field points to an array of Primary Information Plug record structures.
|
|
* The end of the array is indicated by a plug record of which all fields are zero.
|
|
*/
|
|
typedef struct {
|
|
char signature[14+1+1]; // signature (see DHF.C) + C/LE-Bin/BE-Bin-flag + format version
|
|
CFG_PROG_STRCT FAR *codep; //
|
|
hcf_32 execution; // Execution address of the firmware
|
|
void FAR *place_holder_1;
|
|
void FAR *place_holder_2;
|
|
CFG_RANGE20_STRCT FAR *compat; // Pointer to the compatibility info records
|
|
CFG_IDENTITY_STRCT FAR *identity; // Pointer to the identity info records
|
|
void FAR *p[2]; /* (Up to 9) pointers for (future) expansion
|
|
* currently in use:
|
|
* - F/W printf information
|
|
*/
|
|
} memimage;
|
|
|
|
|
|
|
|
/*-----------------------------------------------------------------------------
|
|
*
|
|
* DHF function prototypes
|
|
*
|
|
*---------------------------------------------------------------------------*/
|
|
|
|
EXTERN_C int dhf_download_fw( void *ifbp, memimage *fw ); // ifbp, ignored when using the UIL
|
|
EXTERN_C int dhf_download_binary( memimage *fw );
|
|
|
|
|
|
/*-----------------------------------------------------------------------------
|
|
*
|
|
* Functions to be provided by the user of the DHF module.
|
|
*
|
|
*---------------------------------------------------------------------------*/
|
|
|
|
// defined in DHF.C; see there for comments
|
|
EXTERN_C hcf_16 *find_record_in_pda( hcf_16 *pdap, hcf_16 code );
|
|
|
|
#endif // DHF_H
|
|
|