a driver for wireless pci cards with the Prism chipset from Intersil
Original version, by Stevens Le Blond and Michael Valkering.
This commit is contained in:
parent
e2932a1180
commit
816f5dd550
10 changed files with 3874 additions and 2 deletions
|
@ -21,6 +21,7 @@ all install depend clean:
|
|||
cd ./floppy && $(MAKE) $@
|
||||
cd ./printer && $(MAKE) $@
|
||||
cd ./rtl8139 && $(MAKE) $@
|
||||
cd ./orinoco && $(MAKE) $@
|
||||
cd ./fxp && $(MAKE) $@
|
||||
cd ./dpeth && $(MAKE) $@
|
||||
cd ./log && $(MAKE) $@
|
||||
|
|
40
drivers/orinoco/INSTALL.txt
Executable file
40
drivers/orinoco/INSTALL.txt
Executable file
|
@ -0,0 +1,40 @@
|
|||
The driver has been tested on Minix 3.1.3, svn revision 2928:
|
||||
http://derelict.cs.vu.nl/images/minix3_1_3_ide_r2928.iso.bz2
|
||||
|
||||
|
||||
To install the driver do:
|
||||
#sh install_script
|
||||
|
||||
This script will patch, compile and install 2 code files in Minix:
|
||||
/usr/src/services/rs/service.c
|
||||
/usr/src/commands/dhcpd/devices.c
|
||||
(see the docs directory for more information)
|
||||
Furthermore, the script will patch 1 configuration file:
|
||||
/etc/drivers.conf
|
||||
(adding an entry for 'orinoco')
|
||||
and 1 script file:
|
||||
/usr/etc/rc
|
||||
(adding an entry in a for-loop to start orinoco)
|
||||
Finally, the script will copy the orinoco driver into the drivers directory,
|
||||
compile and install it.
|
||||
|
||||
When the script completes successfully, the inet.conf file has to be adjusted
|
||||
so that Minix will use the orinoco driver. Add an entry like:
|
||||
|
||||
eth0 orinoco 0 {default;};
|
||||
|
||||
The last step is to set the essid and WEP key of the network in the boot
|
||||
monitor. When in the boot monitor, type:
|
||||
essid=<essid>
|
||||
wep=<WEP key>
|
||||
save
|
||||
|
||||
The essid is the name of the wireless network
|
||||
The WEP key is a string of 13 ASCII characters, being the key of the wireless
|
||||
network. This variable shouldn't be set when the network is not WEP protected.
|
||||
If the essid is not set, the card will just try connect a network quite at random
|
||||
|
||||
N.B.: WPA is not supported
|
||||
N.B.: WEP seems to be buggy. At my place it works, at the VU it doesnt. So if
|
||||
things don't work, try without WEP
|
||||
|
42
drivers/orinoco/Makefile
Executable file
42
drivers/orinoco/Makefile
Executable file
|
@ -0,0 +1,42 @@
|
|||
# Makefile for the Orinoco wireless card (Prism chipset)
|
||||
DRIVER = orinoco
|
||||
|
||||
# directories
|
||||
u = /usr
|
||||
i = $u/include
|
||||
s = $i/sys
|
||||
m = $i/minix
|
||||
b = $i/ibm
|
||||
d = ..
|
||||
|
||||
# programs, flags, etc.
|
||||
CC = exec cc
|
||||
CFLAGS = -I$i $(CPROFILE)
|
||||
LDFLAGS = -i
|
||||
LIBS = -lsysutil -lsys -ltimers
|
||||
|
||||
OBJ = orinoco.o hermes.o
|
||||
|
||||
# build local binary
|
||||
all build: $(DRIVER)
|
||||
$(DRIVER): $(OBJ)
|
||||
$(CC) -o $@ $(LDFLAGS) $(OBJ) $(LIBS)
|
||||
install -S 100kw $(DRIVER)
|
||||
|
||||
# install with other drivers
|
||||
install: /usr/sbin/$(DRIVER)
|
||||
/usr/sbin/$(DRIVER): $(DRIVER)
|
||||
install -o root -cs $? $@
|
||||
|
||||
# clean up local files
|
||||
clean:
|
||||
rm -f $(DRIVER) *.o *.bak
|
||||
|
||||
depend:
|
||||
mkdep "$(CC) -E $(CPPFLAGS)" *.c > .depend
|
||||
|
||||
# Include generated dependencies.
|
||||
include .depend
|
||||
|
||||
|
||||
|
789
drivers/orinoco/hermes.c
Executable file
789
drivers/orinoco/hermes.c
Executable file
|
@ -0,0 +1,789 @@
|
|||
/*
|
||||
* hermes.c
|
||||
*
|
||||
* This file contains the lower level access functions for Prism based
|
||||
* wireless cards. The file is based on hermes.c of the Linux kernel
|
||||
*
|
||||
* Adjusted to Minix by Stevens Le Blond <slblond@few.vu.nl>
|
||||
* and Michael Valkering <mjvalker@cs.vu.nl>
|
||||
*/
|
||||
|
||||
/* Original copyright notices from Linux hermes.c
|
||||
*
|
||||
* Copyright (C) 2000, David Gibson, Linuxcare Australia
|
||||
* <hermes@gibson.dropbear.id.au>
|
||||
* Copyright (C) 2001, David Gibson, IBM <hermes@gibson.dropbear.id.au>
|
||||
*
|
||||
* The contents of this file are subject to the Mozilla Public License
|
||||
* Version 1.1 (the "License"); you may not use this file except in
|
||||
* compliance with the License. You may obtain a copy of the License
|
||||
* at http://www.mozilla.org/MPL/
|
||||
*
|
||||
* Software distributed under the License is distributed on an "AS IS"
|
||||
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
|
||||
* the License for the specific language governing rights and
|
||||
* limitations under the License.
|
||||
*
|
||||
* Alternatively, the contents of this file may be used under the
|
||||
* terms of the GNU General Public License version 2 (the "GPL"), in
|
||||
* which case the provisions of the GPL are applicable instead of the
|
||||
* above. If you wish to allow the use of your version of this file
|
||||
* only under the terms of the GPL and not to allow others to use your
|
||||
* version of this file under the MPL, indicate your decision by
|
||||
* deleting the provisions above and replace them with the notice and
|
||||
* other provisions required by the GPL. If you do not delete the
|
||||
* provisions above, a recipient may use your version of this file
|
||||
* under either the MPL or the GPL.
|
||||
*/
|
||||
|
||||
#include "hermes.h"
|
||||
#include <sys/vm.h>
|
||||
#include "assert.h"
|
||||
#include <ibm/pci.h>
|
||||
|
||||
#include "string.h"
|
||||
int this_proc;
|
||||
|
||||
#define MICROS_TO_TICKS(m) (((m)*HZ/1000000)+1)
|
||||
|
||||
/*****************************************************************************
|
||||
* milli_delay *
|
||||
* *
|
||||
* Wait usecs micro seconds. Clearly needs revision *
|
||||
*****************************************************************************/
|
||||
static void micro_delay(unsigned long usecs)
|
||||
{
|
||||
int i, j;
|
||||
|
||||
if(usecs >= 100) {
|
||||
/* If the delay is long, we might as well use ticks */
|
||||
tickdelay(MICROS_TO_TICKS(usecs));
|
||||
} else {
|
||||
/* use another type of hack :-), or a proper implementation */
|
||||
for(i=0; i < 1000 * usecs; i++){j+=1;}
|
||||
}
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
* milli_delay *
|
||||
* *
|
||||
* Wait msecs milli seconds *
|
||||
*****************************************************************************/
|
||||
void milli_delay(unsigned int msecs)
|
||||
{
|
||||
micro_delay((long)msecs * 1000);
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_issue_cmd *
|
||||
* *
|
||||
* Issue a command to the chip. Waiting for it to complete is the caller's *
|
||||
* problem. The only thing we have to do first is to see whether we can *
|
||||
* actually write something in the CMD register: is it unbusy? *
|
||||
* Returns -EBUSY if the command register is busy, 0 on success. *
|
||||
*****************************************************************************/
|
||||
static int hermes_issue_cmd (hermes_t * hw, u16_t cmd, u16_t param0) {
|
||||
int k = HERMES_CMD_BUSY_TIMEOUT;
|
||||
u16_t reg;
|
||||
|
||||
/* First wait for the command register to unbusy */
|
||||
reg = hermes_read_reg (hw, HERMES_CMD);
|
||||
while ((reg & HERMES_CMD_BUSY) && k) {
|
||||
k--;
|
||||
micro_delay (1);
|
||||
reg = hermes_read_reg (hw, HERMES_CMD);
|
||||
}
|
||||
/* it takes too long. Bailing out */
|
||||
if (reg & HERMES_CMD_BUSY) {
|
||||
printf("Hermes: HERMES_CMD_BUSY timeout\n");
|
||||
return -EBUSY;
|
||||
}
|
||||
|
||||
/* write the values to the right registers */
|
||||
hermes_write_reg (hw, HERMES_PARAM2, 0);
|
||||
hermes_write_reg (hw, HERMES_PARAM1, 0);
|
||||
hermes_write_reg (hw, HERMES_PARAM0, param0);
|
||||
hermes_write_reg (hw, HERMES_CMD, cmd);
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_struct_init *
|
||||
* *
|
||||
* Initialize the hermes structure fields *
|
||||
*****************************************************************************/
|
||||
void hermes_struct_init (hermes_t * hw, u32_t address,
|
||||
int io_space, int reg_spacing) {
|
||||
hw->iobase = address;
|
||||
hw->io_space = io_space;
|
||||
hw->reg_spacing = reg_spacing;
|
||||
hw->inten = 0x0;
|
||||
this_proc = getprocnr();
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_cor_reset *
|
||||
* *
|
||||
* This is the first step in initializing the card's firmware and hardware: *
|
||||
* write HERMES_PCI_COR_MASK to the Configuration Option Register *
|
||||
*****************************************************************************/
|
||||
int hermes_cor_reset (hermes_t *hw) {
|
||||
int k, i;
|
||||
u16_t reg;
|
||||
|
||||
/* Assert the reset until the card notice */
|
||||
hermes_write_reg (hw, HERMES_PCI_COR, HERMES_PCI_COR_MASK);
|
||||
|
||||
milli_delay (HERMES_PCI_COR_ONT);
|
||||
|
||||
/* Give time for the card to recover from this hard effort */
|
||||
hermes_write_reg (hw, HERMES_PCI_COR, 0x0000);
|
||||
|
||||
milli_delay (HERMES_PCI_COR_OFFT);
|
||||
|
||||
/* The card is ready when it's no longer busy */
|
||||
k = HERMES_PCI_COR_BUSYT;
|
||||
reg = hermes_read_reg (hw, HERMES_CMD);
|
||||
while (k && (reg & HERMES_CMD_BUSY)) {
|
||||
k--;
|
||||
milli_delay (1);
|
||||
reg = hermes_read_reg (hw, HERMES_CMD);
|
||||
}
|
||||
|
||||
/* Did we timeout ? */
|
||||
if (reg & HERMES_CMD_BUSY) {
|
||||
printf ("Busy timeout after resetting the COR\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
return (0);
|
||||
}
|
||||
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_init *
|
||||
* *
|
||||
* Initialize the card *
|
||||
*****************************************************************************/
|
||||
int hermes_init (hermes_t * hw) {
|
||||
u32_t status, reg, resp0;
|
||||
int err = 0;
|
||||
int k;
|
||||
|
||||
/* We don't want to be interrupted while resetting the chipset. By
|
||||
* setting the control mask for hardware interrupt generation to 0,
|
||||
* we won't be disturbed*/
|
||||
hw->inten = 0x0;
|
||||
hermes_write_reg (hw, HERMES_INTEN, 0);
|
||||
|
||||
/* Acknowledge any pending events waiting for acknowledgement. We
|
||||
* assume there won't be any important to take care off */
|
||||
hermes_write_reg (hw, HERMES_EVACK, 0xffff);
|
||||
|
||||
/* Normally it's a "can't happen" for the command register to
|
||||
* be busy when we go to issue a command because we are
|
||||
* serializing all commands. However we want to have some
|
||||
* chance of resetting the card even if it gets into a stupid
|
||||
* state, so we actually wait to see if the command register
|
||||
* will unbusy itself here. */
|
||||
k = HERMES_CMD_BUSY_TIMEOUT;
|
||||
reg = hermes_read_reg (hw, HERMES_CMD);
|
||||
while (k && (reg & HERMES_CMD_BUSY)) {
|
||||
if (reg == 0xffff) {
|
||||
/* Special case - the card has probably
|
||||
* been removed, so don't wait for the
|
||||
* timeout */
|
||||
printf("Hermes: Card removed?\n");
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
k--;
|
||||
micro_delay (1);
|
||||
reg = hermes_read_reg (hw, HERMES_CMD);
|
||||
}
|
||||
|
||||
/* No need to explicitly handle the timeout - if we've timed
|
||||
* out hermes_issue_cmd() will probably return -EBUSY below.
|
||||
* But i check to be sure :-) */
|
||||
if (reg & HERMES_CMD_BUSY) {
|
||||
printf("Hermes: Timeout waiting for the CMD_BUSY to unset\n");
|
||||
return -EBUSY;
|
||||
}
|
||||
|
||||
/* According to the documentation, EVSTAT may contain
|
||||
* obsolete event occurrence information. We have to acknowledge
|
||||
* it by writing EVACK. */
|
||||
reg = hermes_read_reg (hw, HERMES_EVSTAT);
|
||||
hermes_write_reg (hw, HERMES_EVACK, reg);
|
||||
|
||||
err = hermes_issue_cmd (hw, HERMES_CMD_INIT, 0);
|
||||
if (err){
|
||||
printf("Hermes: errornr: 0x%x issueing HERMES_CMD_INIT\n",
|
||||
err);
|
||||
return err;
|
||||
}
|
||||
|
||||
/* here we start waiting for the above command,CMD_INIT, to complete.
|
||||
* Completion is noticeable when the HERMES_EV_CMD bit in the
|
||||
* HERMES_EVSTAT register is set to 1 */
|
||||
reg = hermes_read_reg (hw, HERMES_EVSTAT);
|
||||
k = HERMES_CMD_INIT_TIMEOUT;
|
||||
while ((!(reg & HERMES_EV_CMD)) && k) {
|
||||
k--;
|
||||
micro_delay (10);
|
||||
reg = hermes_read_reg (hw, HERMES_EVSTAT);
|
||||
}
|
||||
|
||||
|
||||
/* the software support register 0 (there are 3) is filled with a
|
||||
* magic number. With this one can test the availability of the card */
|
||||
hermes_write_reg (hw, HERMES_SWSUPPORT0, HERMES_MAGIC);
|
||||
|
||||
if (!hermes_present (hw)) {
|
||||
printf("Hermes: Card not present?: got mag. nr.0x%x\n",
|
||||
hermes_read_reg (hw, HERMES_SWSUPPORT0));
|
||||
}
|
||||
|
||||
if (!(reg & HERMES_EV_CMD)) {
|
||||
printf("hermes @ %x: Timeout waiting for card to reset\n",
|
||||
hw->iobase);
|
||||
return -ETIMEDOUT;
|
||||
}
|
||||
|
||||
status = hermes_read_reg (hw, HERMES_STATUS);
|
||||
resp0 = hermes_read_reg (hw, HERMES_RESP0);
|
||||
|
||||
/* after having issued the command above, the completion set a bit in
|
||||
* the EVSTAT register. This has to be acknowledged, as follows */
|
||||
hermes_write_reg (hw, HERMES_EVACK, HERMES_EV_CMD);
|
||||
|
||||
/* Was the status, the result of the issued command, ok? */
|
||||
/* The expression below should be zero. Non-zero means an error */
|
||||
if (status & HERMES_STATUS_RESULT) {
|
||||
printf("Hermes:Result of INIT_CMD wrong.error value: 0x%x\n",
|
||||
(status & HERMES_STATUS_RESULT) >> 8);
|
||||
err = -EIO;
|
||||
}
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_docmd_wait *
|
||||
* *
|
||||
* Issue a command to the chip, and (busy) wait for it to complete. *
|
||||
*****************************************************************************/
|
||||
int hermes_docmd_wait (hermes_t * hw, u16_t cmd, u16_t parm0,
|
||||
hermes_response_t * resp) {
|
||||
int err;
|
||||
int k;
|
||||
u16_t reg;
|
||||
u16_t status;
|
||||
|
||||
err = hermes_issue_cmd (hw, cmd, parm0);
|
||||
if (err) {
|
||||
printf("hermes @ %x: Error %d issuing command.\n",
|
||||
hw->iobase, err);
|
||||
return err;
|
||||
}
|
||||
|
||||
/* Reads the Event status register. When the command has completed,
|
||||
* the fourth bit in the HERMES_EVSTAT register is a 1. We will be
|
||||
* waiting for that to happen */
|
||||
reg = hermes_read_reg (hw, HERMES_EVSTAT);
|
||||
k = HERMES_CMD_COMPL_TIMEOUT;
|
||||
while ((!(reg & HERMES_EV_CMD)) && k) {
|
||||
k--;
|
||||
micro_delay (10);
|
||||
reg = hermes_read_reg (hw, HERMES_EVSTAT);
|
||||
}
|
||||
|
||||
/* check for a timeout: has the command still not completed? */
|
||||
if (!(reg & HERMES_EV_CMD)) {
|
||||
printf("hermes @ %x: Timeout waiting for command \
|
||||
completion.\n", hw->iobase);
|
||||
err = -ETIMEDOUT;
|
||||
return err;
|
||||
}
|
||||
|
||||
status = hermes_read_reg (hw, HERMES_STATUS);
|
||||
/* some commands result in results residing in response registers.
|
||||
* They have to be read before the acknowledgement below.
|
||||
*/
|
||||
if (resp) {
|
||||
resp->status = status;
|
||||
resp->resp0 = hermes_read_reg (hw, HERMES_RESP0);
|
||||
resp->resp1 = hermes_read_reg (hw, HERMES_RESP1);
|
||||
resp->resp2 = hermes_read_reg (hw, HERMES_RESP2);
|
||||
}
|
||||
|
||||
/* After issueing a Command, the card expects an Acknowledgement */
|
||||
hermes_write_reg (hw, HERMES_EVACK, HERMES_EV_CMD);
|
||||
|
||||
/* check whether there has been a valid value in the Status register.
|
||||
* the high order bits should have at least some value */
|
||||
if (status & HERMES_STATUS_RESULT) {
|
||||
printf("Hermes: EIO\n");
|
||||
err = -EIO;
|
||||
}
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_allocate *
|
||||
* *
|
||||
* Allocate bufferspace in the card, which will be then available for *
|
||||
* writing by the host, TX buffers. The card will try to find enough memory *
|
||||
* (creating a list of 128 byte blocks) and will return a pointer to the *
|
||||
* first block. This pointer is a pointer to the frame identifier (fid), *
|
||||
* holding information and data of the buffer. The fid is like a file *
|
||||
* descriptor, a value indicating some resource *
|
||||
*****************************************************************************/
|
||||
int hermes_allocate (hermes_t * hw, u16_t size, u16_t * fid) {
|
||||
int err = 0;
|
||||
int k;
|
||||
u16_t reg;
|
||||
|
||||
if ((size < HERMES_ALLOC_LEN_MIN) || (size > HERMES_ALLOC_LEN_MAX)) {
|
||||
printf("Hermes: Invalid size\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* Issue a allocation request to the card, waiting for the command
|
||||
* to complete */
|
||||
err = hermes_docmd_wait (hw, HERMES_CMD_ALLOC, size, NULL);
|
||||
if (err) {
|
||||
printf( "Hermes: docmd_wait timeout\n");
|
||||
return err;
|
||||
}
|
||||
|
||||
/* Read the status event register to know whether the allocation
|
||||
* succeeded. The HERMES_EV_ALLOC bit should be set */
|
||||
reg = hermes_read_reg (hw, HERMES_EVSTAT);
|
||||
k = HERMES_ALLOC_COMPL_TIMEOUT;
|
||||
while ((!(reg & HERMES_EV_ALLOC)) && k) {
|
||||
k--;
|
||||
micro_delay (10);
|
||||
reg = hermes_read_reg (hw, HERMES_EVSTAT);
|
||||
}
|
||||
|
||||
/* tired of waiting to complete. Abort. */
|
||||
if (!(reg & HERMES_EV_ALLOC)) {
|
||||
printf("hermes @ %x:Timeout waiting for frame allocation\n",
|
||||
hw->iobase);
|
||||
return -ETIMEDOUT;
|
||||
}
|
||||
|
||||
/* When we come here, everything has gone well. The pointer to the
|
||||
* fid is in the ALLOCFID register. This fid is later on used
|
||||
* to access this buffer */
|
||||
*fid = hermes_read_reg (hw, HERMES_ALLOCFID);
|
||||
|
||||
/* always acknowledge the receipt of an event */
|
||||
hermes_write_reg (hw, HERMES_EVACK, HERMES_EV_ALLOC);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_bap_seek *
|
||||
* *
|
||||
* Set up a Buffer Access Path (BAP) to read a particular chunk of data *
|
||||
* from card's internal buffer. Setting a bap register is like doing a fseek *
|
||||
* system call: setting an internal pointer to the right place in a buffer *
|
||||
*****************************************************************************/
|
||||
static int hermes_bap_seek (hermes_t * hw, int bap, u16_t id, u16_t offset) {
|
||||
|
||||
/* There are 2 BAPs. This can be used to use the access buffers
|
||||
* concurrently: 1 for writing in the TX buffer and 1 for reading
|
||||
* a RX buffer in case of an RX interrupt.
|
||||
* The BAP consists of 2 registers, together with which one can
|
||||
* point to a single byte in the required buffer (additionally
|
||||
* there is a third register, but that one is not used in this
|
||||
* function, the data register). With the SELECT register one chooses
|
||||
* the fid, with the OFFSET register one chooses the offset in the fid
|
||||
* buffer */
|
||||
int sreg = bap ? HERMES_SELECT1 : HERMES_SELECT0;
|
||||
int oreg = bap ? HERMES_OFFSET1 : HERMES_OFFSET0;
|
||||
int resp0;
|
||||
int k;
|
||||
u16_t reg;
|
||||
|
||||
/* Check whether the offset is not too large, and whether it is a
|
||||
* number of words. Offset can't be odd */
|
||||
if ((offset > HERMES_BAP_OFFSET_MAX) || (offset % 2)) {
|
||||
printf("Hermes: Offset error\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* We can't write to the offset register when the busy flag is set. If
|
||||
* it is set, wait to automatically reset*/
|
||||
k = HERMES_BAP_BUSY_TIMEOUT;
|
||||
reg = hermes_read_reg (hw, oreg);
|
||||
while ((reg & HERMES_OFFSET_BUSY) && k) {
|
||||
k--;
|
||||
micro_delay (1);
|
||||
reg = hermes_read_reg (hw, oreg);
|
||||
}
|
||||
|
||||
/* For some reason, the busy flag didn't reset automatically. Return */
|
||||
if (reg & HERMES_OFFSET_BUSY) {
|
||||
printf("Hermes: HERMES_OFFSET_BUSY still set, oreg: 0x%x\n",
|
||||
reg);
|
||||
return -ETIMEDOUT;
|
||||
}
|
||||
|
||||
/* Now we actually set up the transfer. Write the fid in the select
|
||||
* register, and the offset in the offset register */
|
||||
hermes_write_reg (hw, sreg, id);
|
||||
hermes_write_reg (hw, oreg, offset);
|
||||
|
||||
/* Wait for the BAP to be ready. This means that at first the
|
||||
* OFFSET_BUSY bit is set by the card once we have written the values
|
||||
* above. We wait until the card has done its internal processing and
|
||||
* unset the OFFSET_BUSY bit */
|
||||
k = HERMES_BAP_BUSY_TIMEOUT;
|
||||
reg = hermes_read_reg (hw, oreg);
|
||||
while ((reg & (HERMES_OFFSET_BUSY | HERMES_OFFSET_ERR)) && k) {
|
||||
k--;
|
||||
micro_delay (1);
|
||||
reg = hermes_read_reg (hw, oreg);
|
||||
}
|
||||
|
||||
/* Busy bit didn't reset automatically */
|
||||
if (reg & HERMES_OFFSET_BUSY) {
|
||||
printf("Hermes: Error with fid 0x%x. Err: 0x%x\n", id, reg);
|
||||
return -ETIMEDOUT;
|
||||
}
|
||||
|
||||
/* There has gone something wrong: offset is outside the buffer
|
||||
* boundary or the fid is not correct */
|
||||
if (reg & HERMES_OFFSET_ERR) {
|
||||
printf("Hermes: Error with fid 0x%x. Err: 0x%x\n", id, reg);
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
/* If we arrive here, the buffer can be accessed through the data
|
||||
* register associated with the BAP */
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_bap_pread *
|
||||
* *
|
||||
* Read a block of data from the chip's buffer, via the BAP. len must be *
|
||||
* even. *
|
||||
*****************************************************************************/
|
||||
int hermes_bap_pread (hermes_t * hw, int bap, void *buf, unsigned len,
|
||||
u16_t id, u16_t offset) {
|
||||
/* The data register is the access point for the buffer made
|
||||
* available by setting the BAP right. Which BAP does the user
|
||||
* want to use? there are 2 of them */
|
||||
int dreg = bap ? HERMES_DATA1 : HERMES_DATA0;
|
||||
int err = 0;
|
||||
|
||||
/* reading (and writing) data goes a word a time, so should be even */
|
||||
if ((len < 0) || (len % 2)) {
|
||||
printf("Hermes: Error in length to be read\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* Set the cards internal pointer to the right fid and to the right
|
||||
* offset */
|
||||
err = hermes_bap_seek (hw, bap, id, offset);
|
||||
if (err) {
|
||||
printf("Hermes: error hermes_bap_seek in hermes_bap_pread\n");
|
||||
return err;
|
||||
}
|
||||
/* Actually do the transfer. The length is divided by 2 because
|
||||
* transfers go a word at a time as far as the card is concerned */
|
||||
hermes_read_words (hw, dreg, buf, len / 2);
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_bap_pwrite *
|
||||
* *
|
||||
* Write a block of data to the chip's buffer, via the BAP. len must be even.*
|
||||
*****************************************************************************/
|
||||
int hermes_bap_pwrite (hermes_t * hw, int bap, const void *buf, unsigned len,
|
||||
u16_t id, u16_t offset) {
|
||||
|
||||
/* This procedure is quite the same as the hermes_bap_read */
|
||||
int dreg = bap ? HERMES_DATA1 : HERMES_DATA0;
|
||||
int err = 0;
|
||||
|
||||
if ((len < 0) || (len % 2)) {
|
||||
printf("Hermes: Error in length to be written\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* Set the cards internal pointer to the right fid and to the right
|
||||
* offset */
|
||||
err = hermes_bap_seek (hw, bap, id, offset);
|
||||
if (err) {
|
||||
printf("Hermes: hermes_bap_seek error in hermes_bap_pwrite\n");
|
||||
return err;
|
||||
|
||||
}
|
||||
|
||||
/* Actually do the transfer */
|
||||
hermes_write_words (hw, dreg, buf, len / 2);
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_present *
|
||||
* *
|
||||
* Check whether we have access to the card. Does the SWSUPPORT0 contain the *
|
||||
* value we put in it earlier? *
|
||||
*****************************************************************************/
|
||||
int hermes_present (hermes_t * hw) {
|
||||
int i = hermes_read_reg (hw, HERMES_SWSUPPORT0) == HERMES_MAGIC;
|
||||
if (!i)
|
||||
printf("Hermes: Error, card not present?\n");
|
||||
return i;
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_set_irqmask *
|
||||
* *
|
||||
* Which events should the card respond to with an interrupt? *
|
||||
*****************************************************************************/
|
||||
int hermes_set_irqmask (hermes_t * hw, u16_t events) {
|
||||
hw->inten = events;
|
||||
hermes_write_reg (hw, HERMES_INTEN, events);
|
||||
|
||||
/* Compare written value with read value to check whether things
|
||||
* succeeded */
|
||||
if (hermes_read_reg (hw, HERMES_INTEN) != events) {
|
||||
printf("Hermes: error setting irqmask\n");
|
||||
return 1;
|
||||
}
|
||||
|
||||
return (0);
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_set_irqmask *
|
||||
* *
|
||||
* Which events does the card respond to with an interrupt? *
|
||||
*****************************************************************************/
|
||||
u16_t hermes_get_irqmask (hermes_t * hw) {
|
||||
return hermes_read_reg (hw, HERMES_INTEN);
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_read_ltv *
|
||||
* *
|
||||
* Read a Length-Type-Value record from the card. These are configurable *
|
||||
* parameters in the cards firmware, like wepkey, essid, mac address etc. *
|
||||
* Another name for them are 'rids', Resource Identifiers. See hermes_rids.h *
|
||||
* for all available rids *
|
||||
* If length is NULL, we ignore the length read from the card, and *
|
||||
* read the entire buffer regardless. This is useful because some of *
|
||||
* the configuration records appear to have incorrect lengths in *
|
||||
* practice. *
|
||||
*****************************************************************************/
|
||||
int hermes_read_ltv (hermes_t * hw, int bap, u16_t rid, unsigned bufsize,
|
||||
u16_t * length, void *buf) {
|
||||
int err = 0;
|
||||
int dreg = bap ? HERMES_DATA1 : HERMES_DATA0;
|
||||
u16_t rlength, rtype;
|
||||
unsigned nwords;
|
||||
|
||||
if ((bufsize < 0) || (bufsize % 2)) {
|
||||
printf("Hermes: error in bufsize\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
err = hermes_docmd_wait (hw, HERMES_CMD_ACCESS, rid, NULL);
|
||||
if (err) {
|
||||
printf("Hermes: error hermes_docmd_wait in hermes_read_ltv\n");
|
||||
return err;
|
||||
}
|
||||
|
||||
err = hermes_bap_seek (hw, bap, rid, 0);
|
||||
if (err) {
|
||||
printf("Hermes: error hermes_bap_seek in hermes_read_ltv\n");
|
||||
return err;
|
||||
}
|
||||
|
||||
rlength = hermes_read_reg (hw, dreg);
|
||||
|
||||
if (!rlength) {
|
||||
printf( "Hermes: Error rlength\n");
|
||||
return -ENOENT;
|
||||
}
|
||||
|
||||
rtype = hermes_read_reg (hw, dreg);
|
||||
|
||||
if (length)
|
||||
*length = rlength;
|
||||
|
||||
if (rtype != rid) {
|
||||
printf("hermes @ %lx: hermes_read_ltv(): rid (0x%04x)",
|
||||
hw->iobase);
|
||||
printf("does not match type (0x%04x)\n", rid, rtype);
|
||||
}
|
||||
|
||||
if (HERMES_RECLEN_TO_BYTES (rlength) > bufsize) {
|
||||
printf("hermes @ %lx: Truncating LTV record from ",
|
||||
hw->iobase);
|
||||
printf("%d to %d bytes. (rid=0x%04x, len=0x%04x)\n",
|
||||
HERMES_RECLEN_TO_BYTES (rlength), bufsize, rid,
|
||||
rlength);
|
||||
}
|
||||
nwords = MIN ((unsigned) rlength - 1, bufsize / 2);
|
||||
hermes_read_words (hw, dreg, buf, nwords);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_write_ltv *
|
||||
* *
|
||||
* Write a Length-Type-Value record to the card. These are configurable *
|
||||
* parameters in the cards firmware, like wepkey, essid, mac address etc. *
|
||||
* Another name for them are 'rids', Resource Identifiers. See hermes_rids.h *
|
||||
* for all available rids *
|
||||
*****************************************************************************/
|
||||
int hermes_write_ltv (hermes_t * hw, int bap, u16_t rid,
|
||||
u16_t length, const void *value) {
|
||||
int dreg = bap ? HERMES_DATA1 : HERMES_DATA0;
|
||||
int err = 0;
|
||||
unsigned count;
|
||||
|
||||
if (length == 0) {
|
||||
printf("Hermes: length==0 in hermes_write_ltv\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
err = hermes_bap_seek (hw, bap, rid, 0);
|
||||
if (err) {
|
||||
printf("Hermes: error hermes_bap_seek in hermes_write_ltv\n");
|
||||
return err;
|
||||
}
|
||||
|
||||
hermes_write_reg (hw, dreg, length);
|
||||
hermes_write_reg (hw, dreg, rid);
|
||||
|
||||
count = length - 1;
|
||||
|
||||
hermes_write_words (hw, dreg, value, count);
|
||||
|
||||
err = hermes_docmd_wait (hw, HERMES_CMD_ACCESS | HERMES_CMD_WRITE,
|
||||
rid, NULL);
|
||||
if (err)
|
||||
printf("Hermes: error hermes_docmd_wait in hermes_write_ltv\n");
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_write_wordrec *
|
||||
* *
|
||||
* A shorthand for hermes_write_ltv when the field is 2 bytes long *
|
||||
*****************************************************************************/
|
||||
int hermes_write_wordrec (hermes_t * hw, int bap, u16_t rid, u16_t word) {
|
||||
|
||||
u16_t rec;
|
||||
int err;
|
||||
rec = (word);
|
||||
|
||||
err = hermes_write_ltv (hw, bap, rid,
|
||||
HERMES_BYTES_TO_RECLEN (sizeof (rec)), &rec);
|
||||
|
||||
if (err)
|
||||
printf("Hermes: error in write_wordrec\n");
|
||||
return err;
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_read_wordrec *
|
||||
* *
|
||||
* A shorthand for hermes_read_ltv when the field is 2 bytes long *
|
||||
*****************************************************************************/
|
||||
int hermes_read_wordrec (hermes_t * hw, int bap, u16_t rid, u16_t * word) {
|
||||
u16_t rec;
|
||||
int err;
|
||||
|
||||
err = hermes_read_ltv (hw, bap, rid, sizeof (rec), NULL, &rec);
|
||||
*word = (rec);
|
||||
if (err)
|
||||
printf("Hermes: Error in read_wordrec\n");
|
||||
return err;
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_read_words *
|
||||
* *
|
||||
* Read a sequence of words from the card to the buffer *
|
||||
*****************************************************************************/
|
||||
void hermes_read_words (hermes_t * hw, int off, void *buf, unsigned count) {
|
||||
int i = 0;
|
||||
u16_t reg;
|
||||
|
||||
for (i = 0; i < count; i++) {
|
||||
reg = hermes_read_reg (hw, off);
|
||||
*((u16_t *) buf + i) = (u16_t) reg;
|
||||
}
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_write_words *
|
||||
* *
|
||||
* Write a sequence of words of the buffer to the card *
|
||||
*****************************************************************************/
|
||||
void hermes_write_words (hermes_t * hw, int off, const void *buf,
|
||||
unsigned count) {
|
||||
int i = 0;
|
||||
|
||||
for (i = 0; i < count; i++) {
|
||||
hermes_write_reg (hw, off, *((u16_t *) buf + i));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_read_reg *
|
||||
* *
|
||||
* Read a value from a certain register. Currently only memory mapped *
|
||||
* registers are supported, but accessing I/O spaced registers should be *
|
||||
* quite trivial *
|
||||
*****************************************************************************/
|
||||
u16_t hermes_read_reg (hermes_t * hw, u16_t off) {
|
||||
int v = 0;
|
||||
v = *((int *)(hw->locmem + (off << hw->reg_spacing)));
|
||||
return (u16_t) v;
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
* hermes_write_reg *
|
||||
* *
|
||||
* Write a value to a certain register. Currently only memory mapped *
|
||||
* registers are supported, but accessing I/O spaced registers should be *
|
||||
* quite trivial *
|
||||
*****************************************************************************/
|
||||
void hermes_write_reg (hermes_t * hw, u16_t off, u16_t val) {
|
||||
int v = (int) val;
|
||||
*(int *)(hw->locmem + (off << hw->reg_spacing)) = v;
|
||||
}
|
||||
|
339
drivers/orinoco/hermes.h
Executable file
339
drivers/orinoco/hermes.h
Executable file
|
@ -0,0 +1,339 @@
|
|||
/*
|
||||
* hermes.h
|
||||
*
|
||||
* Constants, structures and prototypes needed for the low level access of
|
||||
* Prism cards. The hermes.h file was used as the basis of this file
|
||||
*
|
||||
* Adjusted to Minix by Stevens Le Blond <slblond@few.vu.nl>
|
||||
* and Michael Valkering <mjvalker@cs.vu.nl>
|
||||
*/
|
||||
|
||||
/* Original copyright notices from hermes.h of the Linux kernel
|
||||
*
|
||||
* Copyright (C) 2000, David Gibson, Linuxcare Australia
|
||||
* <hermes@gibson.dropbear.id.au>
|
||||
* Portions taken from hfa384x.h, Copyright (C) 1999 AbsoluteValue Systems, Inc.
|
||||
* All Rights Reserved.
|
||||
* This file distributed under the GPL, version 2.
|
||||
*/
|
||||
#ifndef _HERMES_H
|
||||
#define _HERMES_H
|
||||
|
||||
#include "../drivers.h"
|
||||
#include <net/gen/ether.h>
|
||||
#include <net/gen/eth_io.h>
|
||||
#include <net/hton.h>
|
||||
#include <stdarg.h>
|
||||
|
||||
/*****************************************************************************
|
||||
* HERMES CONSTANTS *
|
||||
*****************************************************************************/
|
||||
#define HERMES_ALLOC_LEN_MIN (4)
|
||||
#define HERMES_ALLOC_LEN_MAX (2400)
|
||||
#define HERMES_LTV_LEN_MAX (34)
|
||||
#define HERMES_BAP_DATALEN_MAX (4096)
|
||||
#define HERMES_BAP_OFFSET_MAX (4096)
|
||||
#define HERMES_PORTID_MAX (7)
|
||||
#define HERMES_NUMPORTS_MAX (HERMES_PORTID_MAX+1)
|
||||
#define HERMES_PDR_LEN_MAX (260)
|
||||
#define HERMES_PDA_RECS_MAX (200)
|
||||
#define HERMES_PDA_LEN_MAX (1024)
|
||||
#define HERMES_SCANRESULT_MAX (35)
|
||||
#define HERMES_CHINFORESULT_MAX (8)
|
||||
#define HERMES_MAX_MULTICAST (16)
|
||||
#define HERMES_MAGIC (0x69ff)
|
||||
|
||||
/*
|
||||
* Hermes register offsets
|
||||
*/
|
||||
#define HERMES_CMD (0x00)
|
||||
#define HERMES_PARAM0 (0x02)
|
||||
#define HERMES_PARAM1 (0x04)
|
||||
#define HERMES_PARAM2 (0x06)
|
||||
#define HERMES_STATUS (0x08)
|
||||
#define HERMES_RESP0 (0x0A)
|
||||
#define HERMES_RESP1 (0x0C)
|
||||
#define HERMES_RESP2 (0x0E)
|
||||
#define HERMES_INFOFID (0x10)
|
||||
#define HERMES_RXFID (0x20)
|
||||
#define HERMES_ALLOCFID (0x22)
|
||||
#define HERMES_TXCOMPLFID (0x24)
|
||||
#define HERMES_SELECT0 (0x18)
|
||||
#define HERMES_OFFSET0 (0x1C)
|
||||
#define HERMES_DATA0 (0x36)
|
||||
#define HERMES_SELECT1 (0x1A)
|
||||
#define HERMES_OFFSET1 (0x1E)
|
||||
#define HERMES_DATA1 (0x38)
|
||||
#define HERMES_EVSTAT (0x30)
|
||||
#define HERMES_INTEN (0x32)
|
||||
#define HERMES_EVACK (0x34)
|
||||
#define HERMES_CONTROL (0x14)
|
||||
#define HERMES_SWSUPPORT0 (0x28)
|
||||
#define HERMES_SWSUPPORT1 (0x2A)
|
||||
#define HERMES_SWSUPPORT2 (0x2C)
|
||||
#define HERMES_AUXPAGE (0x3A)
|
||||
#define HERMES_AUXOFFSET (0x3C)
|
||||
#define HERMES_AUXDATA (0x3E)
|
||||
|
||||
/*
|
||||
* CMD register bitmasks
|
||||
*/
|
||||
#define HERMES_CMD_BUSY (0x8000)
|
||||
#define HERMES_CMD_AINFO (0x7f00)
|
||||
#define HERMES_CMD_MACPORT (0x0700)
|
||||
#define HERMES_CMD_RECL (0x0100)
|
||||
#define HERMES_CMD_WRITE (0x0100)
|
||||
#define HERMES_CMD_PROGMODE (0x0300)
|
||||
#define HERMES_CMD_CMDCODE (0x003f)
|
||||
|
||||
/*
|
||||
* STATUS register bitmasks
|
||||
*/
|
||||
#define HERMES_STATUS_RESULT (0x7f00)
|
||||
#define HERMES_STATUS_CMDCODE (0x003f)
|
||||
|
||||
/*
|
||||
* OFFSET register bitmasks
|
||||
*/
|
||||
#define HERMES_OFFSET_BUSY (0x8000)
|
||||
#define HERMES_OFFSET_ERR (0x4000)
|
||||
#define HERMES_OFFSET_DATAOFF (0x0ffe)
|
||||
|
||||
/*
|
||||
* Event register bitmasks (INTEN, EVSTAT, EVACK)
|
||||
*/
|
||||
#define HERMES_EV_TICK (0x8000)
|
||||
#define HERMES_EV_WTERR (0x4000)
|
||||
#define HERMES_EV_INFDROP (0x2000)
|
||||
#define HERMES_EV_INFO (0x0080)
|
||||
#define HERMES_EV_DTIM (0x0020)
|
||||
#define HERMES_EV_CMD (0x0010)
|
||||
#define HERMES_EV_ALLOC (0x0008)
|
||||
#define HERMES_EV_TXEXC (0x0004)
|
||||
#define HERMES_EV_TX (0x0002)
|
||||
#define HERMES_EV_RX (0x0001)
|
||||
|
||||
/*
|
||||
* COR reset options
|
||||
*/
|
||||
#define HERMES_PCI_COR (0x26)
|
||||
#define HERMES_PCI_COR_MASK (0x0080)
|
||||
/* It appears that the card needs quite some time to recover: */
|
||||
#define HERMES_PCI_COR_ONT (250) /* ms */
|
||||
#define HERMES_PCI_COR_OFFT (500) /* ms */
|
||||
#define HERMES_PCI_COR_BUSYT (500) /* ms */
|
||||
/*
|
||||
* Command codes
|
||||
*/
|
||||
/*--- Controller Commands --------------------------*/
|
||||
#define HERMES_CMD_INIT (0x0000)
|
||||
#define HERMES_CMD_ENABLE (0x0001)
|
||||
#define HERMES_CMD_DISABLE (0x0002)
|
||||
#define HERMES_CMD_DIAG (0x0003)
|
||||
|
||||
/*--- Buffer Mgmt Commands --------------------------*/
|
||||
#define HERMES_CMD_ALLOC (0x000A)
|
||||
#define HERMES_CMD_TX (0x000B)
|
||||
#define HERMES_CMD_CLRPRST (0x0012)
|
||||
|
||||
/*--- Regulate Commands --------------------------*/
|
||||
#define HERMES_CMD_NOTIFY (0x0010)
|
||||
#define HERMES_CMD_INQUIRE (0x0011)
|
||||
|
||||
/*--- Configure Commands --------------------------*/
|
||||
#define HERMES_CMD_ACCESS (0x0021)
|
||||
#define HERMES_CMD_DOWNLD (0x0022)
|
||||
|
||||
/*--- Debugging Commands -----------------------------*/
|
||||
#define HERMES_CMD_MONITOR (0x0038)
|
||||
#define HERMES_MONITOR_ENABLE (0x000b)
|
||||
#define HERMES_MONITOR_DISABLE (0x000f)
|
||||
|
||||
/*
|
||||
* Frame structures and constants
|
||||
*/
|
||||
|
||||
#define HERMES_DESCRIPTOR_OFFSET (0)
|
||||
#define HERMES_802_11_OFFSET (14)
|
||||
#define HERMES_802_3_OFFSET (14+32)
|
||||
#define HERMES_802_2_OFFSET (14+32+14)
|
||||
|
||||
struct hermes_rx_descriptor
|
||||
{
|
||||
u16_t status;
|
||||
u16_t time_lefthalf;
|
||||
u16_t time_righthalf;
|
||||
u8_t silence;
|
||||
u8_t signal;
|
||||
u8_t rate;
|
||||
u8_t rxflow;
|
||||
u16_t reserved1;
|
||||
u16_t reserved2;
|
||||
};
|
||||
|
||||
#define HERMES_RXSTAT_ERR (0x0003)
|
||||
#define HERMES_RXSTAT_BADCRC (0x0001)
|
||||
#define HERMES_RXSTAT_UNDECRYPTABLE (0x0002)
|
||||
#define HERMES_RXSTAT_MACPORT (0x0700)
|
||||
#define HERMES_RXSTAT_PCF (0x1000)
|
||||
#define HERMES_RXSTAT_MSGTYPE (0xE000)
|
||||
#define HERMES_RXSTAT_1042 (0x2000) /* RFC-1042 frame */
|
||||
#define HERMES_RXSTAT_TUNNEL (0x4000) /* bridge-tunnel
|
||||
* encoded frame */
|
||||
#define HERMES_RXSTAT_WMP (0x6000) /* Wavelan-II
|
||||
* Management
|
||||
* Protocol frame */
|
||||
|
||||
struct hermes_tx_descriptor
|
||||
{
|
||||
u16_t status;
|
||||
u16_t reserved1;
|
||||
u16_t reserved2;
|
||||
u16_t sw_support_lefthalf;
|
||||
u16_t sw_support_righthalf;
|
||||
u8_t retry_count;
|
||||
u8_t tx_rate;
|
||||
u16_t tx_control;
|
||||
};
|
||||
|
||||
#define HERMES_TXSTAT_RETRYERR (0x0001)
|
||||
#define HERMES_TXSTAT_AGEDERR (0x0002)
|
||||
#define HERMES_TXSTAT_DISCON (0x0004)
|
||||
#define HERMES_TXSTAT_FORMERR (0x0008)
|
||||
|
||||
#define HERMES_TXCTRL_TX_OK (0x0002)
|
||||
#define HERMES_TXCTRL_TX_EX (0x0004)
|
||||
#define HERMES_TXCTRL_802_11 (0x0008)
|
||||
#define HERMES_TXCTRL_ALT_RTRY (0x0020)
|
||||
|
||||
/* Inquiry constants and data types */
|
||||
|
||||
#define HERMES_INQ_TALLIES (0xF100)
|
||||
#define HERMES_INQ_SCAN (0xF101)
|
||||
#define HERMES_INQ_LINKSTATUS (0xF200)
|
||||
|
||||
|
||||
/* The tallies are retrieved, but these fields are not processed until now */
|
||||
struct hermes_tallies_frame
|
||||
{
|
||||
u16_t TxUnicastFrames;
|
||||
u16_t TxMulticastFrames;
|
||||
u16_t TxFragments;
|
||||
u16_t TxUnicastOctets;
|
||||
u16_t TxMulticastOctets;
|
||||
u16_t TxDeferredTransmissions;
|
||||
u16_t TxSingleRetryFrames;
|
||||
u16_t TxMultipleRetryFrames;
|
||||
u16_t TxRetryLimitExceeded;
|
||||
u16_t TxDiscards;
|
||||
u16_t RxUnicastFrames;
|
||||
u16_t RxMulticastFrames;
|
||||
u16_t RxFragments;
|
||||
u16_t RxUnicastOctets;
|
||||
u16_t RxMulticastOctets;
|
||||
u16_t RxFCSErrors;
|
||||
u16_t RxDiscards_NoBuffer;
|
||||
u16_t TxDiscardsWrongSA;
|
||||
u16_t RxWEPUndecryptable;
|
||||
u16_t RxMsgInMsgFragments;
|
||||
u16_t RxMsgInBadMsgFragments;
|
||||
u16_t RxDiscards_WEPICVError;
|
||||
u16_t RxDiscards_WEPExcluded;
|
||||
};
|
||||
|
||||
#define HERMES_LINKSTATUS_NOT_CONNECTED (0x0000)
|
||||
#define HERMES_LINKSTATUS_CONNECTED (0x0001)
|
||||
#define HERMES_LINKSTATUS_DISCONNECTED (0x0002)
|
||||
#define HERMES_LINKSTATUS_AP_CHANGE (0x0003)
|
||||
#define HERMES_LINKSTATUS_AP_OUT_OF_RANGE (0x0004)
|
||||
#define HERMES_LINKSTATUS_AP_IN_RANGE (0x0005)
|
||||
#define HERMES_LINKSTATUS_ASSOC_FAILED (0x0006)
|
||||
|
||||
struct hermes_linkstatus
|
||||
{
|
||||
u16_t linkstatus; /* Link status */
|
||||
};
|
||||
|
||||
/* Timeouts. These are maximum timeouts. Most often, card wil react
|
||||
* much faster */
|
||||
#define HERMES_BAP_BUSY_TIMEOUT (10000) /* In iterations of ~1us */
|
||||
#define HERMES_CMD_BUSY_TIMEOUT (100) /* In iterations of ~1us */
|
||||
#define HERMES_CMD_INIT_TIMEOUT (50000) /* in iterations of ~10us */
|
||||
#define HERMES_CMD_COMPL_TIMEOUT (20000) /* in iterations of ~10us */
|
||||
#define HERMES_ALLOC_COMPL_TIMEOUT (1000) /* in iterations of ~10us */
|
||||
|
||||
/* WEP settings */
|
||||
#define HERMES_AUTH_OPEN (1)
|
||||
#define HERMES_AUTH_SHARED_KEY (2)
|
||||
#define HERMES_WEP_PRIVACY_INVOKED (0x0001)
|
||||
#define HERMES_WEP_EXCL_UNENCRYPTED (0x0002)
|
||||
#define HERMES_WEP_HOST_ENCRYPT (0x0010)
|
||||
#define HERMES_WEP_HOST_DECRYPT (0x0080)
|
||||
|
||||
|
||||
/* Basic control structure */
|
||||
typedef struct hermes
|
||||
{
|
||||
u32_t iobase;
|
||||
int io_space; /* 1 if we IO-mapped IO, 0 for memory-mapped
|
||||
* IO */
|
||||
#define HERMES_IO 1
|
||||
#define HERMES_MEM 0
|
||||
int reg_spacing;
|
||||
#define HERMES_16BIT_REGSPACING 0
|
||||
#define HERMES_32BIT_REGSPACING 1
|
||||
u16_t inten; /* Which interrupts should be enabled? */
|
||||
char *locmem;
|
||||
} hermes_t;
|
||||
|
||||
typedef struct hermes_response
|
||||
{
|
||||
u16_t status, resp0, resp1, resp2;
|
||||
} hermes_response_t;
|
||||
|
||||
struct hermes_idstring
|
||||
{
|
||||
u16_t len;
|
||||
u16_t val[16];
|
||||
};
|
||||
|
||||
#define HERMES_BYTES_TO_RECLEN(n) ( (((n)+1)/2) + 1 )
|
||||
#define HERMES_RECLEN_TO_BYTES(n) ( ((n)-1) * 2 )
|
||||
|
||||
/* Function prototypes */
|
||||
_PROTOTYPE (u16_t hermes_read_reg, (hermes_t * hw, u16_t off));
|
||||
_PROTOTYPE (void hermes_write_reg, (hermes_t * hw, u16_t off, u16_t val));
|
||||
_PROTOTYPE (void hermes_struct_init, (hermes_t * hw, u32_t address,
|
||||
int io_space, int reg_spacing));
|
||||
_PROTOTYPE (int hermes_init, (hermes_t * hw));
|
||||
_PROTOTYPE (int hermes_docmd_wait, (hermes_t * hw, u16_t cmd,
|
||||
u16_t parm0, hermes_response_t * resp));
|
||||
_PROTOTYPE (int hermes_allocate, (hermes_t * hw, u16_t size, u16_t * fid));
|
||||
_PROTOTYPE (int hermes_bap_pread, (hermes_t * hw, int bap, void *buf,
|
||||
unsigned len, u16_t id, u16_t offset));
|
||||
_PROTOTYPE (int hermes_bap_pwrite, (hermes_t * hw, int bap,
|
||||
const void *buf, unsigned len, u16_t id,
|
||||
u16_t offset));
|
||||
_PROTOTYPE (void hermes_read_words, (hermes_t * hw, int off, void *buf,
|
||||
unsigned count));
|
||||
_PROTOTYPE (void hermes_write_words, (hermes_t * hw, int off,
|
||||
const void *buf, unsigned count));
|
||||
_PROTOTYPE (int hermes_read_ltv, (hermes_t * hw, int bap, u16_t rid,
|
||||
unsigned buflen, u16_t * length,
|
||||
void *buf));
|
||||
_PROTOTYPE (int hermes_write_ltv, (hermes_t * hw, int bap, u16_t rid,
|
||||
u16_t length, const void *value));
|
||||
_PROTOTYPE (int hermes_present, (hermes_t * hw));
|
||||
_PROTOTYPE (int myfunc_read, (vir_bytes src));
|
||||
_PROTOTYPE (void myfunc_write, (vir_bytes dst, int val));
|
||||
_PROTOTYPE (void hermes_print_ioarea, (hermes_t * hw, int first_reg,
|
||||
int last_reg));
|
||||
_PROTOTYPE (int hermes_set_irqmask, (hermes_t * hw, u16_t events));
|
||||
_PROTOTYPE (u16_t hermes_get_irqmask, (hermes_t * hw));
|
||||
_PROTOTYPE (int hermes_read_wordrec, (hermes_t * hw, int bap, u16_t rid,
|
||||
u16_t * word));
|
||||
_PROTOTYPE (int hermes_write_wordrec, (hermes_t * hw, int bap, u16_t rid,
|
||||
u16_t word));
|
||||
_PROTOTYPE (int hermes_cor_reset, (hermes_t *hw));
|
||||
_PROTOTYPE (void milli_delay, (unsigned int msecs));
|
||||
#endif /* _HERMES_H */
|
149
drivers/orinoco/hermes_rid.h
Executable file
149
drivers/orinoco/hermes_rid.h
Executable file
|
@ -0,0 +1,149 @@
|
|||
/* hermes_rid.h
|
||||
*
|
||||
* This file contains the RIDs (Resource IDentifiers). These are data items
|
||||
* which are configurable in the card. Most of them are not used in our driver
|
||||
* currently, as you can see there are really a lot which can be configured.
|
||||
*/
|
||||
|
||||
|
||||
#ifndef _HERMES_RID_H
|
||||
#define _HERMES_RID_H
|
||||
|
||||
#define HERMES_RID_CNFPORTTYPE 0xFC00
|
||||
#define HERMES_RID_CNFOWNMACADDR 0xFC01
|
||||
#define HERMES_RID_CNFDESIREDSSID 0xFC02
|
||||
#define HERMES_RID_CNFOWNCHANNEL 0xFC03
|
||||
#define HERMES_RID_CNFOWNSSID 0xFC04
|
||||
#define HERMES_RID_CNFOWNATIMWINDOW 0xFC05
|
||||
#define HERMES_RID_CNFSYSTEMSCALE 0xFC06
|
||||
#define HERMES_RID_CNFMAXDATALEN 0xFC07
|
||||
#define HERMES_RID_CNFWDSADDRESS 0xFC08
|
||||
#define HERMES_RID_CNFPMENABLED 0xFC09
|
||||
#define HERMES_RID_CNFPMEPS 0xFC0A
|
||||
#define HERMES_RID_CNFMULTICASTRECEIVE 0xFC0B
|
||||
#define HERMES_RID_CNFMAXSLEEPDURATION 0xFC0C
|
||||
#define HERMES_RID_CNFPMHOLDOVERDURATION 0xFC0D
|
||||
#define HERMES_RID_CNFOWNNAME 0xFC0E
|
||||
#define HERMES_RID_CNFOWNDTIMPERIOD 0xFC10
|
||||
#define HERMES_RID_CNFWDSADDRESS1 0xFC11
|
||||
#define HERMES_RID_CNFWDSADDRESS2 0xFC12
|
||||
#define HERMES_RID_CNFWDSADDRESS3 0xFC13
|
||||
#define HERMES_RID_CNFWDSADDRESS4 0xFC14
|
||||
#define HERMES_RID_CNFWDSADDRESS5 0xFC15
|
||||
#define HERMES_RID_CNFWDSADDRESS6 0xFC16
|
||||
#define HERMES_RID_CNFMULTICASTPMBUFFERING 0xFC17
|
||||
#define HERMES_RID_CNFWEPENABLED_AGERE 0xFC20
|
||||
#define HERMES_RID_CNFAUTHENTICATION_AGERE 0xFC21
|
||||
#define HERMES_RID_CNFMANDATORYBSSID_SYMBOL 0xFC21
|
||||
#define HERMES_RID_CNFWEPDEFAULTKEYID 0xFC23
|
||||
#define HERMES_RID_CNFDEFAULTKEY0 0xFC24
|
||||
#define HERMES_RID_CNFDEFAULTKEY1 0xFC25
|
||||
#define HERMES_RID_CNFMWOROBUST_AGERE 0xFC25
|
||||
#define HERMES_RID_CNFDEFAULTKEY2 0xFC26
|
||||
#define HERMES_RID_CNFDEFAULTKEY3 0xFC27
|
||||
#define HERMES_RID_CNFWEPFLAGS_INTERSIL 0xFC28
|
||||
#define HERMES_RID_CNFWEPKEYMAPPINGTABLE 0xFC29
|
||||
#define HERMES_RID_CNFAUTHENTICATION 0xFC2A
|
||||
#define HERMES_RID_CNFMAXASSOCSTA 0xFC2B
|
||||
#define HERMES_RID_CNFKEYLENGTH_SYMBOL 0xFC2B
|
||||
#define HERMES_RID_CNFTXCONTROL 0xFC2C
|
||||
#define HERMES_RID_CNFROAMINGMODE 0xFC2D
|
||||
#define HERMES_RID_CNFHOSTAUTHENTICATION 0xFC2E
|
||||
#define HERMES_RID_CNFRCVCRCERROR 0xFC30
|
||||
#define HERMES_RID_CNFMMLIFE 0xFC31
|
||||
#define HERMES_RID_CNFALTRETRYCOUNT 0xFC32
|
||||
#define HERMES_RID_CNFBEACONINT 0xFC33
|
||||
#define HERMES_RID_CNFAPPCFINFO 0xFC34
|
||||
#define HERMES_RID_CNFSTAPCFINFO 0xFC35
|
||||
#define HERMES_RID_CNFPRIORITYQUSAGE 0xFC37
|
||||
#define HERMES_RID_CNFTIMCTRL 0xFC40
|
||||
#define HERMES_RID_CNFTHIRTY2TALLY 0xFC42
|
||||
#define HERMES_RID_CNFENHSECURITY 0xFC43
|
||||
#define HERMES_RID_CNFGROUPADDRESSES 0xFC80
|
||||
#define HERMES_RID_CNFCREATEIBSS 0xFC81
|
||||
#define HERMES_RID_CNFFRAGMENTATIONTHRESHOLD 0xFC82
|
||||
#define HERMES_RID_CNFRTSTHRESHOLD 0xFC83
|
||||
#define HERMES_RID_CNFTXRATECONTROL 0xFC84
|
||||
#define HERMES_RID_CNFPROMISCUOUSMODE 0xFC85
|
||||
#define HERMES_RID_CNFBASICRATES_SYMBOL 0xFC8A
|
||||
#define HERMES_RID_CNFPREAMBLE_SYMBOL 0xFC8C
|
||||
#define HERMES_RID_CNFFRAGMENTATIONTHRESHOLD0 0xFC90
|
||||
#define HERMES_RID_CNFFRAGMENTATIONTHRESHOLD1 0xFC91
|
||||
#define HERMES_RID_CNFFRAGMENTATIONTHRESHOLD2 0xFC92
|
||||
#define HERMES_RID_CNFFRAGMENTATIONTHRESHOLD3 0xFC93
|
||||
#define HERMES_RID_CNFFRAGMENTATIONTHRESHOLD4 0xFC94
|
||||
#define HERMES_RID_CNFFRAGMENTATIONTHRESHOLD5 0xFC95
|
||||
#define HERMES_RID_CNFFRAGMENTATIONTHRESHOLD6 0xFC96
|
||||
#define HERMES_RID_CNFRTSTHRESHOLD0 0xFC97
|
||||
#define HERMES_RID_CNFRTSTHRESHOLD1 0xFC98
|
||||
#define HERMES_RID_CNFRTSTHRESHOLD2 0xFC99
|
||||
#define HERMES_RID_CNFRTSTHRESHOLD3 0xFC9A
|
||||
#define HERMES_RID_CNFRTSTHRESHOLD4 0xFC9B
|
||||
#define HERMES_RID_CNFRTSTHRESHOLD5 0xFC9C
|
||||
#define HERMES_RID_CNFRTSTHRESHOLD6 0xFC9D
|
||||
#define HERMES_RID_CNFHOSTSCAN_SYMBOL 0xFCAB
|
||||
#define HERMES_RID_CNFSHORTPREAMBLE 0xFCB0
|
||||
#define HERMES_RID_CNFWEPKEYS_AGERE 0xFCB0
|
||||
#define HERMES_RID_CNFEXCLUDELONGPREAMBLE 0xFCB1
|
||||
#define HERMES_RID_CNFTXKEY_AGERE 0xFCB1
|
||||
#define HERMES_RID_CNFAUTHENTICATIONRSPTO 0xFCB2
|
||||
#define HERMES_RID_CNFSCANSSID_AGERE 0xFCB2
|
||||
#define HERMES_RID_CNFBASICRATES 0xFCB3
|
||||
#define HERMES_RID_CNFSUPPORTEDRATES 0xFCB4
|
||||
#define HERMES_RID_CNFTICKTIME 0xFCE0
|
||||
#define HERMES_RID_CNFSCANREQUEST 0xFCE1
|
||||
#define HERMES_RID_CNFJOINREQUEST 0xFCE2
|
||||
#define HERMES_RID_CNFAUTHENTICATESTATION 0xFCE3
|
||||
#define HERMES_RID_CNFCHANNELINFOREQUEST 0xFCE4
|
||||
#define HERMES_RID_CNFHOSTSCAN 0xFCE5
|
||||
#define HERMES_RID_MAXLOADTIME 0xFD00
|
||||
#define HERMES_RID_DOWNLOADBUFFER 0xFD01
|
||||
#define HERMES_RID_PRIID 0xFD02
|
||||
#define HERMES_RID_PRISUPRANGE 0xFD03
|
||||
#define HERMES_RID_CFIACTRANGES 0xFD04
|
||||
#define HERMES_RID_NICSERNUM 0xFD0A
|
||||
#define HERMES_RID_NICID 0xFD0B
|
||||
#define HERMES_RID_MFISUPRANGE 0xFD0C
|
||||
#define HERMES_RID_CFISUPRANGE 0xFD0D
|
||||
#define HERMES_RID_CHANNELLIST 0xFD10
|
||||
#define HERMES_RID_REGULATORYDOMAINS 0xFD11
|
||||
#define HERMES_RID_TEMPTYPE 0xFD12
|
||||
#define HERMES_RID_CIS 0xFD13
|
||||
#define HERMES_RID_STAID 0xFD20
|
||||
#define HERMES_RID_STASUPRANGE 0xFD21
|
||||
#define HERMES_RID_MFIACTRANGES 0xFD22
|
||||
#define HERMES_RID_CFIACTRANGES2 0xFD23
|
||||
#define HERMES_RID_SECONDARYVERSION_SYMBOL 0xFD24
|
||||
#define HERMES_RID_PORTSTATUS 0xFD40
|
||||
#define HERMES_RID_CURRENTSSID 0xFD41
|
||||
#define HERMES_RID_CURRENTBSSID 0xFD42
|
||||
#define HERMES_RID_COMMSQUALITY 0xFD43
|
||||
#define HERMES_RID_CURRENTTXRATE 0xFD44
|
||||
#define HERMES_RID_CURRENTBEACONINTERVAL 0xFD45
|
||||
#define HERMES_RID_CURRENTSCALETHRESHOLDS 0xFD46
|
||||
#define HERMES_RID_PROTOCOLRSPTIME 0xFD47
|
||||
#define HERMES_RID_SHORTRETRYLIMIT 0xFD48
|
||||
#define HERMES_RID_LONGRETRYLIMIT 0xFD49
|
||||
#define HERMES_RID_MAXTRANSMITLIFETIME 0xFD4A
|
||||
#define HERMES_RID_MAXRECEIVELIFETIME 0xFD4B
|
||||
#define HERMES_RID_CFPOLLABLE 0xFD4C
|
||||
#define HERMES_RID_AUTHENTICATIONALGORITHMS 0xFD4D
|
||||
#define HERMES_RID_PRIVACYOPTIONIMPLEMENTED 0xFD4F
|
||||
#define HERMES_RID_DBMCOMMSQUALITY_INTERSIL 0xFD51
|
||||
#define HERMES_RID_CURRENTTXRATE1 0xFD80
|
||||
#define HERMES_RID_CURRENTTXRATE2 0xFD81
|
||||
#define HERMES_RID_CURRENTTXRATE3 0xFD82
|
||||
#define HERMES_RID_CURRENTTXRATE4 0xFD83
|
||||
#define HERMES_RID_CURRENTTXRATE5 0xFD84
|
||||
#define HERMES_RID_CURRENTTXRATE6 0xFD85
|
||||
#define HERMES_RID_OWNMACADDR 0xFD86
|
||||
#define HERMES_RID_SCANRESULTSTABLE 0xFD88
|
||||
#define HERMES_RID_PHYTYPE 0xFDC0
|
||||
#define HERMES_RID_CURRENTCHANNEL 0xFDC1
|
||||
#define HERMES_RID_CURRENTPOWERSTATE 0xFDC2
|
||||
#define HERMES_RID_CCAMODE 0xFDC3
|
||||
#define HERMES_RID_SUPPORTEDDATARATES 0xFDC6
|
||||
#define HERMES_RID_BUILDSEQ 0xFFFE
|
||||
#define HERMES_RID_FWID 0xFFFF
|
||||
|
||||
#endif
|
2383
drivers/orinoco/orinoco.c
Executable file
2383
drivers/orinoco/orinoco.c
Executable file
File diff suppressed because it is too large
Load diff
104
drivers/orinoco/orinoco.h
Executable file
104
drivers/orinoco/orinoco.h
Executable file
|
@ -0,0 +1,104 @@
|
|||
/*
|
||||
* orinoco.h
|
||||
*
|
||||
* This file contains the most important structure for the driver: t_or
|
||||
* and some configurable definitions
|
||||
*
|
||||
* Created by Stevens Le Blond <slblond@few.vu.nl>
|
||||
* and Michael Valkering <mjvalker@cs.vu.nl>
|
||||
*/
|
||||
|
||||
#include <net/gen/ether.h>
|
||||
#include <net/gen/eth_io.h>
|
||||
|
||||
#define NR_RX_BUFS 32
|
||||
|
||||
#define LARGE_KEY_LENGTH 13
|
||||
#define IW_ESSID_MAX_SIZE 32
|
||||
#define OR_PORT_NR 1
|
||||
#define IOVEC_NR 16
|
||||
#define OR_ENVVAR "ORETH"
|
||||
#define OR_NAME "orinoco#n"
|
||||
|
||||
#define IEEE802_11_HLEN 30
|
||||
#define IEEE802_11_DATA_LEN (2304)
|
||||
#define IEEE802_11_FRAME_LEN (IEEE802_11_DATA_LEN + IEEE802_11_HLEN + 3)
|
||||
|
||||
typedef struct s_or
|
||||
{
|
||||
int or_irq;
|
||||
int or_hook_id;
|
||||
int or_mode;
|
||||
int or_flags;
|
||||
char *or_model;
|
||||
int or_client;
|
||||
int or_link_up;
|
||||
int or_got_int;
|
||||
int or_tx_alive;
|
||||
int or_send_int;
|
||||
int or_clear_rx;
|
||||
u32_t or_base_port;
|
||||
int or_need_reset;
|
||||
int or_report_link;
|
||||
|
||||
/* Events */
|
||||
int or_ev_rx;
|
||||
int or_ev_tx;
|
||||
int or_ev_info;
|
||||
int or_ev_txexc;
|
||||
int or_ev_alloc;
|
||||
int connected;
|
||||
u16_t channel_mask;
|
||||
u16_t channel;
|
||||
u16_t ap_density;
|
||||
u16_t rts_thresh;
|
||||
int bitratemode;
|
||||
int last_linkstatus;
|
||||
int max_data_len;
|
||||
int port_type;
|
||||
|
||||
/* Rx */
|
||||
phys_bytes or_rx_buf;
|
||||
vir_bytes or_read_s;
|
||||
u16_t rxfid[NR_RX_BUFS];
|
||||
int rx_length[NR_RX_BUFS];
|
||||
u8_t rx_buf[NR_RX_BUFS][IEEE802_11_FRAME_LEN];
|
||||
u8_t rx_offset[NR_RX_BUFS];
|
||||
int rx_first;
|
||||
int rx_last;
|
||||
int rx_current;
|
||||
|
||||
/* Tx */
|
||||
u16_t or_nicbuf_size;
|
||||
vir_bytes or_transm_s;
|
||||
int or_tx_head;
|
||||
int or_tx_tail;
|
||||
|
||||
struct
|
||||
{
|
||||
int ret_busy;
|
||||
u16_t or_txfid;
|
||||
} or_tx;
|
||||
u32_t or_ertxth;
|
||||
|
||||
/* PCI related */
|
||||
int or_seen;
|
||||
u8_t or_pci_bus;
|
||||
u8_t or_pci_dev;
|
||||
u8_t or_pci_func;
|
||||
int devind;
|
||||
|
||||
/* 'large' items */
|
||||
irq_hook_t or_hook;
|
||||
eth_stat_t or_stat;
|
||||
message or_rx_mess;
|
||||
message or_tx_mess;
|
||||
ether_addr_t or_address;
|
||||
iovec_t or_iovec[IOVEC_NR];
|
||||
iovec_s_t or_iovec_s[IOVEC_NR];
|
||||
char or_name[sizeof (OR_NAME)];
|
||||
hermes_t hw;
|
||||
char nick[IW_ESSID_MAX_SIZE + 1];
|
||||
|
||||
|
||||
} t_or;
|
|
@ -207,3 +207,27 @@ driver printer
|
|||
SAFECOPYTO # 32
|
||||
;
|
||||
};
|
||||
|
||||
driver orinoco
|
||||
{
|
||||
system
|
||||
PRIVCTL # 4
|
||||
DEVIO # 21
|
||||
GETINFO # 26
|
||||
UMAP # 14
|
||||
IRQCTL # 19
|
||||
DEVIO # 21
|
||||
#SDEVIO # 22
|
||||
SETALARM # 24
|
||||
TIMES # 25
|
||||
GETINFO # 26
|
||||
SAFECOPYFROM # 31
|
||||
SAFECOPYTO # 32
|
||||
SETGRANT # 34
|
||||
VM_MAP # 30
|
||||
;
|
||||
pci device 1260/3873;
|
||||
uid 0;
|
||||
};
|
||||
|
||||
|
||||
|
|
|
@ -91,7 +91,7 @@ start)
|
|||
fi
|
||||
|
||||
# start only network drivers that are in use
|
||||
for driver in lance rtl8139 fxp dpeth dp8390
|
||||
for driver in lance rtl8139 fxp dpeth dp8390 orinoco
|
||||
do
|
||||
if grep " $driver " /etc/inet.conf > /dev/null 2>&1
|
||||
then
|
||||
|
@ -135,7 +135,8 @@ start)
|
|||
echo -n "Starting networking:"
|
||||
if grep -s 'psip0.*default' /etc/inet.conf
|
||||
then ifconfig -h 10.0.0.1
|
||||
else daemonize dhcpd
|
||||
else sleep 5
|
||||
daemonize dhcpd
|
||||
fi
|
||||
daemonize nonamed -L
|
||||
if [ -f "$DAEMONS" ]
|
||||
|
|
Loading…
Reference in a new issue