Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
6c2447fd
Commit
6c2447fd
authored
Oct 09, 2004
by
Richard Russon
Browse files
Options
Browse Files
Download
Plain Diff
Merge flatcap.org:/home/flatcap/backup/bk/ntfs-2.6
into flatcap.org:/home/flatcap/backup/bk/ntfs-2.6-devel
parents
3064c00f
cb281c89
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
128 additions
and
126 deletions
+128
-126
arch/arm/boot/compressed/head.S
arch/arm/boot/compressed/head.S
+14
-0
arch/arm/kernel/ecard.c
arch/arm/kernel/ecard.c
+23
-44
arch/arm/mm/proc-v6.S
arch/arm/mm/proc-v6.S
+3
-5
drivers/net/wireless/ray_cs.c
drivers/net/wireless/ray_cs.c
+84
-73
drivers/net/wireless/ray_cs.h
drivers/net/wireless/ray_cs.h
+3
-3
include/asm-arm/page.h
include/asm-arm/page.h
+1
-1
No files found.
arch/arm/boot/compressed/head.S
View file @
6c2447fd
...
@@ -593,6 +593,12 @@ proc_types:
...
@@ -593,6 +593,12 @@ proc_types:
b
__armv4_cache_off
b
__armv4_cache_off
b
__armv4_cache_flush
b
__armv4_cache_flush
.
word
0x00070000
@
ARMv6
.
word
0x000f0000
b
__armv4_cache_on
b
__armv4_cache_off
b
__armv6_cache_flush
.
word
0
@
unrecognised
type
.
word
0
@
unrecognised
type
.
word
0
.
word
0
mov
pc
,
lr
mov
pc
,
lr
...
@@ -652,6 +658,14 @@ cache_clean_flush:
...
@@ -652,6 +658,14 @@ cache_clean_flush:
mov
r3
,
#
16
mov
r3
,
#
16
b
call_cache_fn
b
call_cache_fn
__armv6_cache_flush
:
mov
r1
,
#
0
mcr
p15
,
0
,
r1
,
c7
,
c14
,
0
@
clean
+
invalidate
D
mcr
p15
,
0
,
r1
,
c7
,
c5
,
0
@
invalidate
I
+
BTB
mcr
p15
,
0
,
r1
,
c7
,
c15
,
0
@
clean
+
invalidate
unified
mcr
p15
,
0
,
r1
,
c7
,
c10
,
4
@
drain
WB
mov
pc
,
lr
__armv4_cache_flush
:
__armv4_cache_flush
:
mov
r2
,
#
64
*
1024
@
default
:
32
K
dcache
size
(*
2
)
mov
r2
,
#
64
*
1024
@
default
:
32
K
dcache
size
(*
2
)
mov
r11
,
#
32
@
default
:
32
byte
line
size
mov
r11
,
#
32
@
default
:
32
byte
line
size
...
...
arch/arm/kernel/ecard.c
View file @
6c2447fd
...
@@ -33,6 +33,7 @@
...
@@ -33,6 +33,7 @@
#include <linux/types.h>
#include <linux/types.h>
#include <linux/sched.h>
#include <linux/sched.h>
#include <linux/interrupt.h>
#include <linux/interrupt.h>
#include <linux/completion.h>
#include <linux/reboot.h>
#include <linux/reboot.h>
#include <linux/mm.h>
#include <linux/mm.h>
#include <linux/slab.h>
#include <linux/slab.h>
...
@@ -53,18 +54,14 @@
...
@@ -53,18 +54,14 @@
#define HAVE_EXPMASK
#define HAVE_EXPMASK
#endif
#endif
enum
req
{
req_readbytes
,
req_reset
};
struct
ecard_request
{
struct
ecard_request
{
enum
req
req
;
void
(
*
fn
)(
struct
ecard_request
*
)
;
ecard_t
*
ec
;
ecard_t
*
ec
;
unsigned
int
address
;
unsigned
int
address
;
unsigned
int
length
;
unsigned
int
length
;
unsigned
int
use_loader
;
unsigned
int
use_loader
;
void
*
buffer
;
void
*
buffer
;
struct
completion
*
complete
;
};
};
struct
expcard_blacklist
{
struct
expcard_blacklist
{
...
@@ -129,15 +126,14 @@ slot_to_ecard(unsigned int slot)
...
@@ -129,15 +126,14 @@ slot_to_ecard(unsigned int slot)
#define POD_INT_ADDR(x) ((volatile unsigned char *)\
#define POD_INT_ADDR(x) ((volatile unsigned char *)\
((BUS_ADDR((x)) - IO_BASE) + IO_START))
((BUS_ADDR((x)) - IO_BASE) + IO_START))
static
inline
void
ecard_task_reset
(
struct
ecard_request
*
req
)
static
void
ecard_task_reset
(
struct
ecard_request
*
req
)
{
{
struct
expansion_card
*
ec
=
req
->
ec
;
struct
expansion_card
*
ec
=
req
->
ec
;
if
(
ec
->
loader
)
if
(
ec
->
loader
)
ecard_loader_reset
(
POD_INT_ADDR
(
ec
->
podaddr
),
ec
->
loader
);
ecard_loader_reset
(
POD_INT_ADDR
(
ec
->
podaddr
),
ec
->
loader
);
}
}
static
void
static
void
ecard_task_readbytes
(
struct
ecard_request
*
req
)
ecard_task_readbytes
(
struct
ecard_request
*
req
)
{
{
unsigned
char
*
buf
=
(
unsigned
char
*
)
req
->
buffer
;
unsigned
char
*
buf
=
(
unsigned
char
*
)
req
->
buffer
;
volatile
unsigned
char
*
base_addr
=
volatile
unsigned
char
*
base_addr
=
...
@@ -206,26 +202,9 @@ ecard_task_readbytes(struct ecard_request *req)
...
@@ -206,26 +202,9 @@ ecard_task_readbytes(struct ecard_request *req)
}
}
static
void
ecard_do_request
(
struct
ecard_request
*
req
)
static
DECLARE_WAIT_QUEUE_HEAD
(
ecard_wait
);
{
switch
(
req
->
req
)
{
case
req_readbytes
:
ecard_task_readbytes
(
req
);
break
;
case
req_reset
:
ecard_task_reset
(
req
);
break
;
}
}
#include <linux/completion.h>
static
pid_t
ecard_pid
;
static
wait_queue_head_t
ecard_wait
;
static
struct
ecard_request
*
ecard_req
;
static
struct
ecard_request
*
ecard_req
;
static
DECLARE_MUTEX
(
ecard_sem
);
static
DECLARE_MUTEX
(
ecard_sem
);
static
DECLARE_COMPLETION
(
ecard_completion
);
/*
/*
* Set up the expansion card daemon's page tables.
* Set up the expansion card daemon's page tables.
...
@@ -299,9 +278,10 @@ ecard_task(void * unused)
...
@@ -299,9 +278,10 @@ ecard_task(void * unused)
wait_event_interruptible
(
ecard_wait
,
ecard_req
!=
NULL
);
wait_event_interruptible
(
ecard_wait
,
ecard_req
!=
NULL
);
req
=
xchg
(
&
ecard_req
,
NULL
);
req
=
xchg
(
&
ecard_req
,
NULL
);
if
(
req
!=
NULL
)
if
(
req
!=
NULL
)
{
ecard_do_request
(
req
);
req
->
fn
(
req
);
complete
(
&
ecard_completion
);
complete
(
req
->
complete
);
}
}
}
}
}
...
@@ -311,17 +291,11 @@ ecard_task(void * unused)
...
@@ -311,17 +291,11 @@ ecard_task(void * unused)
* FIXME: The test here is not sufficient to detect if the
* FIXME: The test here is not sufficient to detect if the
* kcardd is running.
* kcardd is running.
*/
*/
static
void
static
void
ecard_call
(
struct
ecard_request
*
req
)
ecard_call
(
struct
ecard_request
*
req
)
{
{
/*
DECLARE_COMPLETION
(
completion
);
* Make sure we have a context that is able to sleep.
*/
if
(
current
==
&
init_task
||
in_interrupt
())
BUG
();
if
(
ecard_pid
<=
0
)
req
->
complete
=
&
completion
;
ecard_pid
=
kernel_thread
(
ecard_task
,
NULL
,
CLONE_KERNEL
);
down
(
&
ecard_sem
);
down
(
&
ecard_sem
);
ecard_req
=
req
;
ecard_req
=
req
;
...
@@ -330,7 +304,7 @@ ecard_call(struct ecard_request *req)
...
@@ -330,7 +304,7 @@ ecard_call(struct ecard_request *req)
/*
/*
* Now wait for kecardd to run.
* Now wait for kecardd to run.
*/
*/
wait_for_completion
(
&
ecard_
completion
);
wait_for_completion
(
&
completion
);
up
(
&
ecard_sem
);
up
(
&
ecard_sem
);
}
}
...
@@ -341,7 +315,7 @@ ecard_readbytes(void *addr, ecard_t *ec, int off, int len, int useld)
...
@@ -341,7 +315,7 @@ ecard_readbytes(void *addr, ecard_t *ec, int off, int len, int useld)
{
{
struct
ecard_request
req
;
struct
ecard_request
req
;
req
.
req
=
req
_readbytes
;
req
.
fn
=
ecard_task
_readbytes
;
req
.
ec
=
ec
;
req
.
ec
=
ec
;
req
.
address
=
off
;
req
.
address
=
off
;
req
.
length
=
len
;
req
.
length
=
len
;
...
@@ -1061,9 +1035,14 @@ ecard_probe(int slot, card_type_t type)
...
@@ -1061,9 +1035,14 @@ ecard_probe(int slot, card_type_t type)
*/
*/
static
int
__init
ecard_init
(
void
)
static
int
__init
ecard_init
(
void
)
{
{
int
slot
,
irqhw
;
int
slot
,
irqhw
,
ret
;
init_waitqueue_head
(
&
ecard_wait
);
ret
=
kernel_thread
(
ecard_task
,
NULL
,
CLONE_KERNEL
);
if
(
ret
<
0
)
{
printk
(
KERN_ERR
"Ecard: unable to create kernel thread: %d
\n
"
,
ret
);
return
ret
;
}
printk
(
"Probing expansion cards
\n
"
);
printk
(
"Probing expansion cards
\n
"
);
...
@@ -1146,7 +1125,7 @@ static void ecard_drv_shutdown(struct device *dev)
...
@@ -1146,7 +1125,7 @@ static void ecard_drv_shutdown(struct device *dev)
if
(
drv
->
shutdown
)
if
(
drv
->
shutdown
)
drv
->
shutdown
(
ec
);
drv
->
shutdown
(
ec
);
ecard_release
(
ec
);
ecard_release
(
ec
);
req
.
req
=
req
_reset
;
req
.
fn
=
ecard_task
_reset
;
req
.
ec
=
ec
;
req
.
ec
=
ec
;
ecard_call
(
&
req
);
ecard_call
(
&
req
);
}
}
...
...
arch/arm/mm/proc-v6.S
View file @
6c2447fd
...
@@ -189,12 +189,10 @@ cpu_v6_name:
...
@@ -189,12 +189,10 @@ cpu_v6_name:
*
-
cache
type
register
is
implemented
*
-
cache
type
register
is
implemented
*/
*/
__v6_setup
:
__v6_setup
:
mrc
p15
,
0
,
r10
,
c0
,
c0
,
1
@
read
cache
type
register
tst
r10
,
#
1
<<
24
@
Harvard
cache
?
mov
r10
,
#
0
mov
r10
,
#
0
mcr
ne
p15
,
0
,
r10
,
c7
,
c14
,
0
@
clean
+
invalidate
D
cache
mcr
p15
,
0
,
r10
,
c7
,
c14
,
0
@
clean
+
invalidate
D
cache
mcr
ne
p15
,
0
,
r10
,
c7
,
c5
,
0
@
invalidate
I
cache
mcr
p15
,
0
,
r10
,
c7
,
c5
,
0
@
invalidate
I
cache
mcr
eq
p15
,
0
,
r10
,
c7
,
c15
,
0
@
clean
+
invalidate
cache
mcr
p15
,
0
,
r10
,
c7
,
c15
,
0
@
clean
+
invalidate
cache
mcr
p15
,
0
,
r10
,
c7
,
c10
,
4
@
drain
write
buffer
mcr
p15
,
0
,
r10
,
c7
,
c10
,
4
@
drain
write
buffer
mcr
p15
,
0
,
r10
,
c8
,
c7
,
0
@
invalidate
I
+
D
TLBs
mcr
p15
,
0
,
r10
,
c8
,
c7
,
0
@
invalidate
I
+
D
TLBs
mcr
p15
,
0
,
r10
,
c2
,
c0
,
2
@
TTB
control
register
mcr
p15
,
0
,
r10
,
c2
,
c0
,
2
@
TTB
control
register
...
...
drivers/net/wireless/ray_cs.c
View file @
6c2447fd
...
@@ -54,7 +54,6 @@
...
@@ -54,7 +54,6 @@
#include <pcmcia/ds.h>
#include <pcmcia/ds.h>
#include <pcmcia/mem_op.h>
#include <pcmcia/mem_op.h>
#ifdef CONFIG_NET_PCMCIA_RADIO
#include <linux/wireless.h>
#include <linux/wireless.h>
#include <asm/io.h>
#include <asm/io.h>
...
@@ -68,7 +67,6 @@
...
@@ -68,7 +67,6 @@
typedef
struct
iw_statistics
iw_stats
;
typedef
struct
iw_statistics
iw_stats
;
typedef
struct
iw_quality
iw_qual
;
typedef
struct
iw_quality
iw_qual
;
typedef
u_char
mac_addr
[
ETH_ALEN
];
/* Hardware address */
typedef
u_char
mac_addr
[
ETH_ALEN
];
/* Hardware address */
#endif
/* CONFIG_NET_PCMCIA_RADIO */
#include "rayctl.h"
#include "rayctl.h"
#include "ray_cs.h"
#include "ray_cs.h"
...
@@ -112,9 +110,9 @@ static int ray_open(struct net_device *dev);
...
@@ -112,9 +110,9 @@ static int ray_open(struct net_device *dev);
static
int
ray_dev_start_xmit
(
struct
sk_buff
*
skb
,
struct
net_device
*
dev
);
static
int
ray_dev_start_xmit
(
struct
sk_buff
*
skb
,
struct
net_device
*
dev
);
static
void
set_multicast_list
(
struct
net_device
*
dev
);
static
void
set_multicast_list
(
struct
net_device
*
dev
);
static
void
ray_update_multi_list
(
struct
net_device
*
dev
,
int
all
);
static
void
ray_update_multi_list
(
struct
net_device
*
dev
,
int
all
);
static
int
translate_frame
(
ray_dev_t
*
local
,
struct
tx_msg
*
ptx
,
static
int
translate_frame
(
ray_dev_t
*
local
,
struct
tx_msg
__iomem
*
ptx
,
unsigned
char
*
data
,
int
len
);
unsigned
char
*
data
,
int
len
);
static
void
ray_build_header
(
ray_dev_t
*
local
,
struct
tx_msg
*
ptx
,
UCHAR
msg_type
,
static
void
ray_build_header
(
ray_dev_t
*
local
,
struct
tx_msg
__iomem
*
ptx
,
UCHAR
msg_type
,
unsigned
char
*
data
);
unsigned
char
*
data
);
static
void
untranslate
(
ray_dev_t
*
local
,
struct
sk_buff
*
skb
,
int
len
);
static
void
untranslate
(
ray_dev_t
*
local
,
struct
sk_buff
*
skb
,
int
len
);
#if WIRELESS_EXT > 7
/* If wireless extension exist in the kernel */
#if WIRELESS_EXT > 7
/* If wireless extension exist in the kernel */
...
@@ -140,14 +138,14 @@ static void verify_dl_startup(u_long);
...
@@ -140,14 +138,14 @@ static void verify_dl_startup(u_long);
/* Prototypes for interrpt time functions **********************************/
/* Prototypes for interrpt time functions **********************************/
static
irqreturn_t
ray_interrupt
(
int
reg
,
void
*
dev_id
,
struct
pt_regs
*
regs
);
static
irqreturn_t
ray_interrupt
(
int
reg
,
void
*
dev_id
,
struct
pt_regs
*
regs
);
static
void
clear_interrupt
(
ray_dev_t
*
local
);
static
void
clear_interrupt
(
ray_dev_t
*
local
);
static
void
rx_deauthenticate
(
ray_dev_t
*
local
,
struct
rcs
*
prcs
,
static
void
rx_deauthenticate
(
ray_dev_t
*
local
,
struct
rcs
__iomem
*
prcs
,
unsigned
int
pkt_addr
,
int
rx_len
);
unsigned
int
pkt_addr
,
int
rx_len
);
static
int
copy_from_rx_buff
(
ray_dev_t
*
local
,
UCHAR
*
dest
,
int
pkt_addr
,
int
len
);
static
int
copy_from_rx_buff
(
ray_dev_t
*
local
,
UCHAR
*
dest
,
int
pkt_addr
,
int
len
);
static
void
ray_rx
(
struct
net_device
*
dev
,
ray_dev_t
*
local
,
struct
rcs
*
prcs
);
static
void
ray_rx
(
struct
net_device
*
dev
,
ray_dev_t
*
local
,
struct
rcs
__iomem
*
prcs
);
static
void
release_frag_chain
(
ray_dev_t
*
local
,
struct
rcs
*
prcs
);
static
void
release_frag_chain
(
ray_dev_t
*
local
,
struct
rcs
__iomem
*
prcs
);
static
void
rx_authenticate
(
ray_dev_t
*
local
,
struct
rcs
*
prcs
,
static
void
rx_authenticate
(
ray_dev_t
*
local
,
struct
rcs
__iomem
*
prcs
,
unsigned
int
pkt_addr
,
int
rx_len
);
unsigned
int
pkt_addr
,
int
rx_len
);
static
void
rx_data
(
struct
net_device
*
dev
,
struct
rcs
*
prcs
,
unsigned
int
pkt_addr
,
static
void
rx_data
(
struct
net_device
*
dev
,
struct
rcs
__iomem
*
prcs
,
unsigned
int
pkt_addr
,
int
rx_len
);
int
rx_len
);
static
void
associate
(
ray_dev_t
*
local
);
static
void
associate
(
ray_dev_t
*
local
);
...
@@ -540,7 +538,7 @@ static void ray_config(dev_link_t *link)
...
@@ -540,7 +538,7 @@ static void ray_config(dev_link_t *link)
CS_CHECK
(
RequestWindow
,
pcmcia_request_window
(
&
link
->
handle
,
&
req
,
&
link
->
win
));
CS_CHECK
(
RequestWindow
,
pcmcia_request_window
(
&
link
->
handle
,
&
req
,
&
link
->
win
));
mem
.
CardOffset
=
0x0000
;
mem
.
Page
=
0
;
mem
.
CardOffset
=
0x0000
;
mem
.
Page
=
0
;
CS_CHECK
(
MapMemPage
,
pcmcia_map_mem_page
(
link
->
win
,
&
mem
));
CS_CHECK
(
MapMemPage
,
pcmcia_map_mem_page
(
link
->
win
,
&
mem
));
local
->
sram
=
(
UCHAR
*
)(
ioremap
(
req
.
Base
,
req
.
Size
)
);
local
->
sram
=
ioremap
(
req
.
Base
,
req
.
Size
);
/*** Set up 16k window for shared memory (receive buffer) ***************/
/*** Set up 16k window for shared memory (receive buffer) ***************/
req
.
Attributes
=
WIN_DATA_WIDTH_8
|
WIN_MEMORY_TYPE_CM
|
WIN_ENABLE
|
WIN_USE_WAIT
;
req
.
Attributes
=
WIN_DATA_WIDTH_8
|
WIN_MEMORY_TYPE_CM
|
WIN_ENABLE
|
WIN_USE_WAIT
;
...
@@ -550,7 +548,7 @@ static void ray_config(dev_link_t *link)
...
@@ -550,7 +548,7 @@ static void ray_config(dev_link_t *link)
CS_CHECK
(
RequestWindow
,
pcmcia_request_window
(
&
link
->
handle
,
&
req
,
&
local
->
rmem_handle
));
CS_CHECK
(
RequestWindow
,
pcmcia_request_window
(
&
link
->
handle
,
&
req
,
&
local
->
rmem_handle
));
mem
.
CardOffset
=
0x8000
;
mem
.
Page
=
0
;
mem
.
CardOffset
=
0x8000
;
mem
.
Page
=
0
;
CS_CHECK
(
MapMemPage
,
pcmcia_map_mem_page
(
local
->
rmem_handle
,
&
mem
));
CS_CHECK
(
MapMemPage
,
pcmcia_map_mem_page
(
local
->
rmem_handle
,
&
mem
));
local
->
rmem
=
(
UCHAR
*
)(
ioremap
(
req
.
Base
,
req
.
Size
)
);
local
->
rmem
=
ioremap
(
req
.
Base
,
req
.
Size
);
/*** Set up window for attribute memory ***********************************/
/*** Set up window for attribute memory ***********************************/
req
.
Attributes
=
WIN_DATA_WIDTH_8
|
WIN_MEMORY_TYPE_AM
|
WIN_ENABLE
|
WIN_USE_WAIT
;
req
.
Attributes
=
WIN_DATA_WIDTH_8
|
WIN_MEMORY_TYPE_AM
|
WIN_ENABLE
|
WIN_USE_WAIT
;
...
@@ -560,7 +558,7 @@ static void ray_config(dev_link_t *link)
...
@@ -560,7 +558,7 @@ static void ray_config(dev_link_t *link)
CS_CHECK
(
RequestWindow
,
pcmcia_request_window
(
&
link
->
handle
,
&
req
,
&
local
->
amem_handle
));
CS_CHECK
(
RequestWindow
,
pcmcia_request_window
(
&
link
->
handle
,
&
req
,
&
local
->
amem_handle
));
mem
.
CardOffset
=
0x0000
;
mem
.
Page
=
0
;
mem
.
CardOffset
=
0x0000
;
mem
.
Page
=
0
;
CS_CHECK
(
MapMemPage
,
pcmcia_map_mem_page
(
local
->
amem_handle
,
&
mem
));
CS_CHECK
(
MapMemPage
,
pcmcia_map_mem_page
(
local
->
amem_handle
,
&
mem
));
local
->
amem
=
(
UCHAR
*
)(
ioremap
(
req
.
Base
,
req
.
Size
)
);
local
->
amem
=
ioremap
(
req
.
Base
,
req
.
Size
);
DEBUG
(
3
,
"ray_config sram=%p
\n
"
,
local
->
sram
);
DEBUG
(
3
,
"ray_config sram=%p
\n
"
,
local
->
sram
);
DEBUG
(
3
,
"ray_config rmem=%p
\n
"
,
local
->
rmem
);
DEBUG
(
3
,
"ray_config rmem=%p
\n
"
,
local
->
rmem
);
...
@@ -593,12 +591,30 @@ static void ray_config(dev_link_t *link)
...
@@ -593,12 +591,30 @@ static void ray_config(dev_link_t *link)
ray_release
(
link
);
ray_release
(
link
);
}
/* ray_config */
}
/* ray_config */
static
inline
struct
ccs
__iomem
*
ccs_base
(
ray_dev_t
*
dev
)
{
return
dev
->
sram
+
CCS_BASE
;
}
static
inline
struct
rcs
__iomem
*
rcs_base
(
ray_dev_t
*
dev
)
{
/*
* This looks nonsensical, since there is a separate
* RCS_BASE. But the difference between a "struct rcs"
* and a "struct ccs" ends up being in the _index_ off
* the base, so the base pointer is the same for both
* ccs/rcs.
*/
return
dev
->
sram
+
CCS_BASE
;
}
/*===========================================================================*/
/*===========================================================================*/
static
int
ray_init
(
struct
net_device
*
dev
)
static
int
ray_init
(
struct
net_device
*
dev
)
{
{
int
i
;
int
i
;
UCHAR
*
p
;
UCHAR
*
p
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
DEBUG
(
1
,
"ray_init(0x%p)
\n
"
,
dev
);
DEBUG
(
1
,
"ray_init(0x%p)
\n
"
,
dev
);
...
@@ -632,7 +648,7 @@ static int ray_init(struct net_device *dev)
...
@@ -632,7 +648,7 @@ static int ray_init(struct net_device *dev)
local
->
tib_length
=
local
->
startup_res
.
tib_length
;
local
->
tib_length
=
local
->
startup_res
.
tib_length
;
DEBUG
(
2
,
"ray_init tib_length = 0x%02x
\n
"
,
local
->
tib_length
);
DEBUG
(
2
,
"ray_init tib_length = 0x%02x
\n
"
,
local
->
tib_length
);
/* Initialize CCS's to buffer free state */
/* Initialize CCS's to buffer free state */
pccs
=
(
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
);
pccs
=
ccs_base
(
local
);
for
(
i
=
0
;
i
<
NUMBER_OF_CCS
;
i
++
)
{
for
(
i
=
0
;
i
<
NUMBER_OF_CCS
;
i
++
)
{
writeb
(
CCS_BUFFER_FREE
,
&
(
pccs
++
)
->
buffer_status
);
writeb
(
CCS_BUFFER_FREE
,
&
(
pccs
++
)
->
buffer_status
);
}
}
...
@@ -661,7 +677,7 @@ static int dl_startup_params(struct net_device *dev)
...
@@ -661,7 +677,7 @@ static int dl_startup_params(struct net_device *dev)
{
{
int
ccsindex
;
int
ccsindex
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
DEBUG
(
1
,
"dl_startup_params entered
\n
"
);
DEBUG
(
1
,
"dl_startup_params entered
\n
"
);
...
@@ -682,7 +698,7 @@ static int dl_startup_params(struct net_device *dev)
...
@@ -682,7 +698,7 @@ static int dl_startup_params(struct net_device *dev)
/* Fill in the CCS fields for the ECF */
/* Fill in the CCS fields for the ECF */
if
((
ccsindex
=
get_free_ccs
(
local
))
<
0
)
return
-
1
;
if
((
ccsindex
=
get_free_ccs
(
local
))
<
0
)
return
-
1
;
local
->
dl_param_ccs
=
ccsindex
;
local
->
dl_param_ccs
=
ccsindex
;
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
ccsindex
;
pccs
=
ccs_base
(
local
)
+
ccsindex
;
writeb
(
CCS_DOWNLOAD_STARTUP_PARAMS
,
&
pccs
->
cmd
);
writeb
(
CCS_DOWNLOAD_STARTUP_PARAMS
,
&
pccs
->
cmd
);
DEBUG
(
2
,
"dl_startup_params start ccsindex = %d
\n
"
,
local
->
dl_param_ccs
);
DEBUG
(
2
,
"dl_startup_params start ccsindex = %d
\n
"
,
local
->
dl_param_ccs
);
/* Interrupt the firmware to process the command */
/* Interrupt the firmware to process the command */
...
@@ -767,7 +783,7 @@ static void init_startup_params(ray_dev_t *local)
...
@@ -767,7 +783,7 @@ static void init_startup_params(ray_dev_t *local)
static
void
verify_dl_startup
(
u_long
data
)
static
void
verify_dl_startup
(
u_long
data
)
{
{
ray_dev_t
*
local
=
(
ray_dev_t
*
)
data
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
data
;
struct
ccs
*
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
local
->
dl_param_ccs
;
struct
ccs
__iomem
*
pccs
=
ccs_base
(
local
)
+
local
->
dl_param_ccs
;
UCHAR
status
;
UCHAR
status
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
...
@@ -807,7 +823,7 @@ static void verify_dl_startup(u_long data)
...
@@ -807,7 +823,7 @@ static void verify_dl_startup(u_long data)
static
void
start_net
(
u_long
data
)
static
void
start_net
(
u_long
data
)
{
{
ray_dev_t
*
local
=
(
ray_dev_t
*
)
data
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
data
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
int
ccsindex
;
int
ccsindex
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
...
@@ -816,7 +832,7 @@ static void start_net(u_long data)
...
@@ -816,7 +832,7 @@ static void start_net(u_long data)
}
}
/* Fill in the CCS fields for the ECF */
/* Fill in the CCS fields for the ECF */
if
((
ccsindex
=
get_free_ccs
(
local
))
<
0
)
return
;
if
((
ccsindex
=
get_free_ccs
(
local
))
<
0
)
return
;
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
ccsindex
;
pccs
=
ccs_base
(
local
)
+
ccsindex
;
writeb
(
CCS_START_NETWORK
,
&
pccs
->
cmd
);
writeb
(
CCS_START_NETWORK
,
&
pccs
->
cmd
);
writeb
(
0
,
&
pccs
->
var
.
start_network
.
update_param
);
writeb
(
0
,
&
pccs
->
var
.
start_network
.
update_param
);
/* Interrupt the firmware to process the command */
/* Interrupt the firmware to process the command */
...
@@ -834,7 +850,7 @@ static void join_net(u_long data)
...
@@ -834,7 +850,7 @@ static void join_net(u_long data)
{
{
ray_dev_t
*
local
=
(
ray_dev_t
*
)
data
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
data
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
int
ccsindex
;
int
ccsindex
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
...
@@ -844,7 +860,7 @@ static void join_net(u_long data)
...
@@ -844,7 +860,7 @@ static void join_net(u_long data)
}
}
/* Fill in the CCS fields for the ECF */
/* Fill in the CCS fields for the ECF */
if
((
ccsindex
=
get_free_ccs
(
local
))
<
0
)
return
;
if
((
ccsindex
=
get_free_ccs
(
local
))
<
0
)
return
;
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
ccsindex
;
pccs
=
ccs_base
(
local
)
+
ccsindex
;
writeb
(
CCS_JOIN_NETWORK
,
&
pccs
->
cmd
);
writeb
(
CCS_JOIN_NETWORK
,
&
pccs
->
cmd
);
writeb
(
0
,
&
pccs
->
var
.
join_network
.
update_param
);
writeb
(
0
,
&
pccs
->
var
.
join_network
.
update_param
);
writeb
(
0
,
&
pccs
->
var
.
join_network
.
net_initiated
);
writeb
(
0
,
&
pccs
->
var
.
join_network
.
net_initiated
);
...
@@ -1049,10 +1065,10 @@ static int ray_hw_xmit(unsigned char* data, int len, struct net_device* dev,
...
@@ -1049,10 +1065,10 @@ static int ray_hw_xmit(unsigned char* data, int len, struct net_device* dev,
UCHAR
msg_type
)
UCHAR
msg_type
)
{
{
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
int
ccsindex
;
int
ccsindex
;
int
offset
;
int
offset
;
struct
tx_msg
*
ptx
;
/* Address of xmit buffer in PC space */
struct
tx_msg
__iomem
*
ptx
;
/* Address of xmit buffer in PC space */
short
int
addr
;
/* Address of xmit buffer in card space */
short
int
addr
;
/* Address of xmit buffer in card space */
DEBUG
(
3
,
"ray_hw_xmit(data=%p, len=%d, dev=%p)
\n
"
,
data
,
len
,
dev
);
DEBUG
(
3
,
"ray_hw_xmit(data=%p, len=%d, dev=%p)
\n
"
,
data
,
len
,
dev
);
...
@@ -1079,7 +1095,7 @@ static int ray_hw_xmit(unsigned char* data, int len, struct net_device* dev,
...
@@ -1079,7 +1095,7 @@ static int ray_hw_xmit(unsigned char* data, int len, struct net_device* dev,
local
->
stats
.
tx_packets
++
;
local
->
stats
.
tx_packets
++
;
}
}
ptx
=
(
struct
tx_msg
*
)(
local
->
sram
+
addr
)
;
ptx
=
local
->
sram
+
addr
;
ray_build_header
(
local
,
ptx
,
msg_type
,
data
);
ray_build_header
(
local
,
ptx
,
msg_type
,
data
);
if
(
translate
)
{
if
(
translate
)
{
...
@@ -1092,7 +1108,7 @@ static int ray_hw_xmit(unsigned char* data, int len, struct net_device* dev,
...
@@ -1092,7 +1108,7 @@ static int ray_hw_xmit(unsigned char* data, int len, struct net_device* dev,
}
}
/* fill in the CCS */
/* fill in the CCS */
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
ccsindex
;
pccs
=
ccs_base
(
local
)
+
ccsindex
;
len
+=
TX_HEADER_LENGTH
+
offset
;
len
+=
TX_HEADER_LENGTH
+
offset
;
writeb
(
CCS_TX_REQUEST
,
&
pccs
->
cmd
);
writeb
(
CCS_TX_REQUEST
,
&
pccs
->
cmd
);
writeb
(
addr
>>
8
,
&
pccs
->
var
.
tx_request
.
tx_data_ptr
[
0
]);
writeb
(
addr
>>
8
,
&
pccs
->
var
.
tx_request
.
tx_data_ptr
[
0
]);
...
@@ -1119,21 +1135,21 @@ static int ray_hw_xmit(unsigned char* data, int len, struct net_device* dev,
...
@@ -1119,21 +1135,21 @@ static int ray_hw_xmit(unsigned char* data, int len, struct net_device* dev,
return
XMIT_OK
;
return
XMIT_OK
;
}
/* end ray_hw_xmit */
}
/* end ray_hw_xmit */
/*===========================================================================*/
/*===========================================================================*/
static
int
translate_frame
(
ray_dev_t
*
local
,
struct
tx_msg
*
ptx
,
unsigned
char
*
data
,
static
int
translate_frame
(
ray_dev_t
*
local
,
struct
tx_msg
__iomem
*
ptx
,
unsigned
char
*
data
,
int
len
)
int
len
)
{
{
unsigned
short
int
proto
=
((
struct
ethhdr
*
)
data
)
->
h_proto
;
unsigned
short
int
proto
=
((
struct
ethhdr
*
)
data
)
->
h_proto
;
if
(
ntohs
(
proto
)
>=
1536
)
{
/* DIX II ethernet frame */
if
(
ntohs
(
proto
)
>=
1536
)
{
/* DIX II ethernet frame */
DEBUG
(
3
,
"ray_cs translate_frame DIX II
\n
"
);
DEBUG
(
3
,
"ray_cs translate_frame DIX II
\n
"
);
/* Copy LLC header to card buffer */
/* Copy LLC header to card buffer */
memcpy_toio
(
(
UCHAR
*
)
&
ptx
->
var
,
eth2_llc
,
sizeof
(
eth2_llc
));
memcpy_toio
(
&
ptx
->
var
,
eth2_llc
,
sizeof
(
eth2_llc
));
memcpy_toio
(
((
UCHAR
*
)
&
ptx
->
var
)
+
sizeof
(
eth2_llc
),
(
UCHAR
*
)
&
proto
,
2
);
memcpy_toio
(
((
void
__iomem
*
)
&
ptx
->
var
)
+
sizeof
(
eth2_llc
),
(
UCHAR
*
)
&
proto
,
2
);
if
((
proto
==
0xf380
)
||
(
proto
==
0x3781
))
{
if
((
proto
==
0xf380
)
||
(
proto
==
0x3781
))
{
/* This is the selective translation table, only 2 entries */
/* This is the selective translation table, only 2 entries */
writeb
(
0xf8
,
(
UCHAR
*
)
&
((
struct
snaphdr_t
*
)
ptx
->
var
)
->
org
[
3
]);
writeb
(
0xf8
,
&
((
struct
snaphdr_t
__iomem
*
)
ptx
->
var
)
->
org
[
3
]);
}
}
/* Copy body of ethernet packet without ethernet header */
/* Copy body of ethernet packet without ethernet header */
memcpy_toio
((
UCHAR
*
)
&
ptx
->
var
+
sizeof
(
struct
snaphdr_t
),
\
memcpy_toio
((
void
__iomem
*
)
&
ptx
->
var
+
sizeof
(
struct
snaphdr_t
),
\
data
+
ETH_HLEN
,
len
-
ETH_HLEN
);
data
+
ETH_HLEN
,
len
-
ETH_HLEN
);
return
(
int
)
sizeof
(
struct
snaphdr_t
)
-
ETH_HLEN
;
return
(
int
)
sizeof
(
struct
snaphdr_t
)
-
ETH_HLEN
;
}
}
...
@@ -1141,16 +1157,16 @@ static int translate_frame(ray_dev_t *local, struct tx_msg *ptx, unsigned char *
...
@@ -1141,16 +1157,16 @@ static int translate_frame(ray_dev_t *local, struct tx_msg *ptx, unsigned char *
DEBUG
(
3
,
"ray_cs translate_frame 802
\n
"
);
DEBUG
(
3
,
"ray_cs translate_frame 802
\n
"
);
if
(
proto
==
0xffff
)
{
/* evil netware IPX 802.3 without LLC */
if
(
proto
==
0xffff
)
{
/* evil netware IPX 802.3 without LLC */
DEBUG
(
3
,
"ray_cs translate_frame evil IPX
\n
"
);
DEBUG
(
3
,
"ray_cs translate_frame evil IPX
\n
"
);
memcpy_toio
(
(
UCHAR
*
)
&
ptx
->
var
,
data
+
ETH_HLEN
,
len
-
ETH_HLEN
);
memcpy_toio
(
&
ptx
->
var
,
data
+
ETH_HLEN
,
len
-
ETH_HLEN
);
return
0
-
ETH_HLEN
;
return
0
-
ETH_HLEN
;
}
}
memcpy_toio
(
(
UCHAR
*
)
&
ptx
->
var
,
data
+
ETH_HLEN
,
len
-
ETH_HLEN
);
memcpy_toio
(
&
ptx
->
var
,
data
+
ETH_HLEN
,
len
-
ETH_HLEN
);
return
0
-
ETH_HLEN
;
return
0
-
ETH_HLEN
;
}
}
/* TBD do other frame types */
/* TBD do other frame types */
}
/* end translate_frame */
}
/* end translate_frame */
/*===========================================================================*/
/*===========================================================================*/
static
void
ray_build_header
(
ray_dev_t
*
local
,
struct
tx_msg
*
ptx
,
UCHAR
msg_type
,
static
void
ray_build_header
(
ray_dev_t
*
local
,
struct
tx_msg
__iomem
*
ptx
,
UCHAR
msg_type
,
unsigned
char
*
data
)
unsigned
char
*
data
)
{
{
writeb
(
PROTOCOL_VER
|
msg_type
,
&
ptx
->
mac
.
frame_ctl_1
);
writeb
(
PROTOCOL_VER
|
msg_type
,
&
ptx
->
mac
.
frame_ctl_1
);
...
@@ -1633,7 +1649,7 @@ static iw_stats * ray_get_wireless_stats(struct net_device * dev)
...
@@ -1633,7 +1649,7 @@ static iw_stats * ray_get_wireless_stats(struct net_device * dev)
{
{
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
struct
status
*
p
=
(
struct
status
*
)(
local
->
sram
+
STATUS_BASE
)
;
struct
status
__iomem
*
p
=
local
->
sram
+
STATUS_BASE
;
if
(
local
==
(
ray_dev_t
*
)
NULL
)
if
(
local
==
(
ray_dev_t
*
)
NULL
)
return
(
iw_stats
*
)
NULL
;
return
(
iw_stats
*
)
NULL
;
...
@@ -1755,7 +1771,7 @@ static int interrupt_ecf(ray_dev_t *local, int ccs)
...
@@ -1755,7 +1771,7 @@ static int interrupt_ecf(ray_dev_t *local, int ccs)
static
int
get_free_tx_ccs
(
ray_dev_t
*
local
)
static
int
get_free_tx_ccs
(
ray_dev_t
*
local
)
{
{
int
i
;
int
i
;
struct
ccs
*
pccs
=
(
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
);
struct
ccs
__iomem
*
pccs
=
ccs_base
(
local
);
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
...
@@ -1786,7 +1802,7 @@ static int get_free_tx_ccs(ray_dev_t *local)
...
@@ -1786,7 +1802,7 @@ static int get_free_tx_ccs(ray_dev_t *local)
static
int
get_free_ccs
(
ray_dev_t
*
local
)
static
int
get_free_ccs
(
ray_dev_t
*
local
)
{
{
int
i
;
int
i
;
struct
ccs
*
pccs
=
(
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
);
struct
ccs
__iomem
*
pccs
=
ccs_base
(
local
);
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
...
@@ -1863,7 +1879,7 @@ static struct net_device_stats *ray_get_stats(struct net_device *dev)
...
@@ -1863,7 +1879,7 @@ static struct net_device_stats *ray_get_stats(struct net_device *dev)
{
{
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
struct
status
*
p
=
(
struct
status
*
)(
local
->
sram
+
STATUS_BASE
)
;
struct
status
__iomem
*
p
=
local
->
sram
+
STATUS_BASE
;
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
DEBUG
(
2
,
"ray_cs net_device_stats - device not present
\n
"
);
DEBUG
(
2
,
"ray_cs net_device_stats - device not present
\n
"
);
return
&
local
->
stats
;
return
&
local
->
stats
;
...
@@ -1895,7 +1911,7 @@ static void ray_update_parm(struct net_device *dev, UCHAR objid, UCHAR *value, i
...
@@ -1895,7 +1911,7 @@ static void ray_update_parm(struct net_device *dev, UCHAR objid, UCHAR *value, i
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
int
ccsindex
;
int
ccsindex
;
int
i
;
int
i
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
DEBUG
(
2
,
"ray_update_parm - device not present
\n
"
);
DEBUG
(
2
,
"ray_update_parm - device not present
\n
"
);
...
@@ -1907,7 +1923,7 @@ static void ray_update_parm(struct net_device *dev, UCHAR objid, UCHAR *value, i
...
@@ -1907,7 +1923,7 @@ static void ray_update_parm(struct net_device *dev, UCHAR objid, UCHAR *value, i
DEBUG
(
0
,
"ray_update_parm - No free ccs
\n
"
);
DEBUG
(
0
,
"ray_update_parm - No free ccs
\n
"
);
return
;
return
;
}
}
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
ccsindex
;
pccs
=
ccs_base
(
local
)
+
ccsindex
;
writeb
(
CCS_UPDATE_PARAMS
,
&
pccs
->
cmd
);
writeb
(
CCS_UPDATE_PARAMS
,
&
pccs
->
cmd
);
writeb
(
objid
,
&
pccs
->
var
.
update_param
.
object_id
);
writeb
(
objid
,
&
pccs
->
var
.
update_param
.
object_id
);
writeb
(
1
,
&
pccs
->
var
.
update_param
.
number_objects
);
writeb
(
1
,
&
pccs
->
var
.
update_param
.
number_objects
);
...
@@ -1926,11 +1942,11 @@ static void ray_update_multi_list(struct net_device *dev, int all)
...
@@ -1926,11 +1942,11 @@ static void ray_update_multi_list(struct net_device *dev, int all)
{
{
struct
dev_mc_list
*
dmi
,
**
dmip
;
struct
dev_mc_list
*
dmi
,
**
dmip
;
int
ccsindex
;
int
ccsindex
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
int
i
=
0
;
int
i
=
0
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
ray_dev_t
*
local
=
(
ray_dev_t
*
)
dev
->
priv
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
UCHAR
*
p
=
local
->
sram
+
HOST_TO_ECF_BASE
;
void
__iomem
*
p
=
local
->
sram
+
HOST_TO_ECF_BASE
;
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
if
(
!
(
link
->
state
&
DEV_PRESENT
))
{
DEBUG
(
2
,
"ray_update_multi_list - device not present
\n
"
);
DEBUG
(
2
,
"ray_update_multi_list - device not present
\n
"
);
...
@@ -1943,7 +1959,7 @@ static void ray_update_multi_list(struct net_device *dev, int all)
...
@@ -1943,7 +1959,7 @@ static void ray_update_multi_list(struct net_device *dev, int all)
DEBUG
(
1
,
"ray_update_multi - No free ccs
\n
"
);
DEBUG
(
1
,
"ray_update_multi - No free ccs
\n
"
);
return
;
return
;
}
}
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
ccsindex
;
pccs
=
ccs_base
(
local
)
+
ccsindex
;
writeb
(
CCS_UPDATE_MULTICAST_LIST
,
&
pccs
->
cmd
);
writeb
(
CCS_UPDATE_MULTICAST_LIST
,
&
pccs
->
cmd
);
if
(
all
)
{
if
(
all
)
{
...
@@ -2011,8 +2027,8 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
...
@@ -2011,8 +2027,8 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
struct
net_device
*
dev
=
(
struct
net_device
*
)
dev_id
;
struct
net_device
*
dev
=
(
struct
net_device
*
)
dev_id
;
dev_link_t
*
link
;
dev_link_t
*
link
;
ray_dev_t
*
local
;
ray_dev_t
*
local
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
struct
rcs
*
prcs
;
struct
rcs
__iomem
*
prcs
;
UCHAR
rcsindex
;
UCHAR
rcsindex
;
UCHAR
tmp
;
UCHAR
tmp
;
UCHAR
cmd
;
UCHAR
cmd
;
...
@@ -2029,7 +2045,7 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
...
@@ -2029,7 +2045,7 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
DEBUG
(
2
,
"ray_cs interrupt from device not present or suspended.
\n
"
);
DEBUG
(
2
,
"ray_cs interrupt from device not present or suspended.
\n
"
);
return
IRQ_NONE
;
return
IRQ_NONE
;
}
}
rcsindex
=
readb
(
&
((
struct
scb
*
)(
local
->
sram
))
->
rcs_index
);
rcsindex
=
readb
(
&
((
struct
scb
__iomem
*
)(
local
->
sram
))
->
rcs_index
);
if
(
rcsindex
>=
(
NUMBER_OF_CCS
+
NUMBER_OF_RCS
))
if
(
rcsindex
>=
(
NUMBER_OF_CCS
+
NUMBER_OF_RCS
))
{
{
...
@@ -2039,7 +2055,7 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
...
@@ -2039,7 +2055,7 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
}
}
if
(
rcsindex
<
NUMBER_OF_CCS
)
/* If it's a returned CCS */
if
(
rcsindex
<
NUMBER_OF_CCS
)
/* If it's a returned CCS */
{
{
pccs
=
((
struct
ccs
*
)
(
local
->
sram
+
CCS_BASE
)
)
+
rcsindex
;
pccs
=
ccs_base
(
local
)
+
rcsindex
;
cmd
=
readb
(
&
pccs
->
cmd
);
cmd
=
readb
(
&
pccs
->
cmd
);
status
=
readb
(
&
pccs
->
buffer_status
);
status
=
readb
(
&
pccs
->
buffer_status
);
switch
(
cmd
)
switch
(
cmd
)
...
@@ -2153,7 +2169,7 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
...
@@ -2153,7 +2169,7 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
}
}
else
/* It's an RCS */
else
/* It's an RCS */
{
{
prcs
=
((
struct
rcs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
rcsindex
;
prcs
=
rcs_base
(
local
)
+
rcsindex
;
switch
(
readb
(
&
prcs
->
interrupt_id
))
switch
(
readb
(
&
prcs
->
interrupt_id
))
{
{
...
@@ -2194,11 +2210,11 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
...
@@ -2194,11 +2210,11 @@ static irqreturn_t ray_interrupt(int irq, void *dev_id, struct pt_regs * regs)
return
IRQ_HANDLED
;
return
IRQ_HANDLED
;
}
/* ray_interrupt */
}
/* ray_interrupt */
/*===========================================================================*/
/*===========================================================================*/
static
void
ray_rx
(
struct
net_device
*
dev
,
ray_dev_t
*
local
,
struct
rcs
*
prcs
)
static
void
ray_rx
(
struct
net_device
*
dev
,
ray_dev_t
*
local
,
struct
rcs
__iomem
*
prcs
)
{
{
int
rx_len
;
int
rx_len
;
unsigned
int
pkt_addr
;
unsigned
int
pkt_addr
;
UCHAR
*
pmsg
;
void
__iomem
*
pmsg
;
DEBUG
(
4
,
"ray_rx process rx packet
\n
"
);
DEBUG
(
4
,
"ray_rx process rx packet
\n
"
);
/* Calculate address of packet within Rx buffer */
/* Calculate address of packet within Rx buffer */
...
@@ -2248,11 +2264,11 @@ static void ray_rx(struct net_device *dev, ray_dev_t *local, struct rcs *prcs)
...
@@ -2248,11 +2264,11 @@ static void ray_rx(struct net_device *dev, ray_dev_t *local, struct rcs *prcs)
}
/* end ray_rx */
}
/* end ray_rx */
/*===========================================================================*/
/*===========================================================================*/
static
void
rx_data
(
struct
net_device
*
dev
,
struct
rcs
*
prcs
,
unsigned
int
pkt_addr
,
static
void
rx_data
(
struct
net_device
*
dev
,
struct
rcs
__iomem
*
prcs
,
unsigned
int
pkt_addr
,
int
rx_len
)
int
rx_len
)
{
{
struct
sk_buff
*
skb
=
NULL
;
struct
sk_buff
*
skb
=
NULL
;
struct
rcs
*
prcslink
=
prcs
;
struct
rcs
__iomem
*
prcslink
=
prcs
;
ray_dev_t
*
local
=
dev
->
priv
;
ray_dev_t
*
local
=
dev
->
priv
;
UCHAR
*
rx_ptr
;
UCHAR
*
rx_ptr
;
int
total_len
;
int
total_len
;
...
@@ -2294,7 +2310,7 @@ static void rx_data(struct net_device *dev, struct rcs *prcs, unsigned int pkt_a
...
@@ -2294,7 +2310,7 @@ static void rx_data(struct net_device *dev, struct rcs *prcs, unsigned int pkt_a
+
readb
(
&
prcslink
->
var
.
rx_packet
.
rx_data_length
[
1
]);
+
readb
(
&
prcslink
->
var
.
rx_packet
.
rx_data_length
[
1
]);
if
(
readb
(
&
prcslink
->
var
.
rx_packet
.
next_frag_rcs_index
)
==
0xFF
if
(
readb
(
&
prcslink
->
var
.
rx_packet
.
next_frag_rcs_index
)
==
0xFF
||
tmp
<
0
)
break
;
||
tmp
<
0
)
break
;
prcslink
=
((
struct
rcs
*
)(
local
->
sram
+
CCS_BASE
)
)
prcslink
=
rcs_base
(
local
)
+
readb
(
&
prcslink
->
link_field
);
+
readb
(
&
prcslink
->
link_field
);
}
while
(
1
);
}
while
(
1
);
...
@@ -2355,7 +2371,7 @@ static void rx_data(struct net_device *dev, struct rcs *prcs, unsigned int pkt_a
...
@@ -2355,7 +2371,7 @@ static void rx_data(struct net_device *dev, struct rcs *prcs, unsigned int pkt_a
prcslink
=
prcs
;
prcslink
=
prcs
;
DEBUG
(
1
,
"ray_cs rx_data in fragment loop
\n
"
);
DEBUG
(
1
,
"ray_cs rx_data in fragment loop
\n
"
);
do
{
do
{
prcslink
=
((
struct
rcs
*
)(
local
->
sram
+
CCS_BASE
)
)
prcslink
=
rcs_base
(
local
)
+
readb
(
&
prcslink
->
var
.
rx_packet
.
next_frag_rcs_index
);
+
readb
(
&
prcslink
->
var
.
rx_packet
.
next_frag_rcs_index
);
rx_len
=
((
readb
(
&
prcslink
->
var
.
rx_packet
.
rx_data_length
[
0
])
<<
8
)
rx_len
=
((
readb
(
&
prcslink
->
var
.
rx_packet
.
rx_data_length
[
0
])
<<
8
)
+
readb
(
&
prcslink
->
var
.
rx_packet
.
rx_data_length
[
1
]))
+
readb
(
&
prcslink
->
var
.
rx_packet
.
rx_data_length
[
1
]))
...
@@ -2529,9 +2545,9 @@ static int copy_from_rx_buff(ray_dev_t *local, UCHAR *dest, int pkt_addr, int le
...
@@ -2529,9 +2545,9 @@ static int copy_from_rx_buff(ray_dev_t *local, UCHAR *dest, int pkt_addr, int le
return
length
;
return
length
;
}
}
/*===========================================================================*/
/*===========================================================================*/
static
void
release_frag_chain
(
ray_dev_t
*
local
,
struct
rcs
*
prcs
)
static
void
release_frag_chain
(
ray_dev_t
*
local
,
struct
rcs
__iomem
*
prcs
)
{
{
struct
rcs
*
prcslink
=
prcs
;
struct
rcs
__iomem
*
prcslink
=
prcs
;
int
tmp
=
17
;
int
tmp
=
17
;
unsigned
rcsindex
=
readb
(
&
prcs
->
var
.
rx_packet
.
next_frag_rcs_index
);
unsigned
rcsindex
=
readb
(
&
prcs
->
var
.
rx_packet
.
next_frag_rcs_index
);
...
@@ -2541,7 +2557,7 @@ static void release_frag_chain(ray_dev_t *local, struct rcs* prcs)
...
@@ -2541,7 +2557,7 @@ static void release_frag_chain(ray_dev_t *local, struct rcs* prcs)
DEBUG
(
1
,
"ray_cs interrupt bad rcsindex = 0x%x
\n
"
,
rcsindex
);
DEBUG
(
1
,
"ray_cs interrupt bad rcsindex = 0x%x
\n
"
,
rcsindex
);
break
;
break
;
}
}
prcslink
=
((
struct
rcs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
rcsindex
;
prcslink
=
rcs_base
(
local
)
+
rcsindex
;
rcsindex
=
readb
(
&
prcslink
->
var
.
rx_packet
.
next_frag_rcs_index
);
rcsindex
=
readb
(
&
prcslink
->
var
.
rx_packet
.
next_frag_rcs_index
);
}
}
writeb
(
CCS_BUFFER_FREE
,
&
prcslink
->
buffer_status
);
writeb
(
CCS_BUFFER_FREE
,
&
prcslink
->
buffer_status
);
...
@@ -2569,7 +2585,7 @@ static void authenticate(ray_dev_t *local)
...
@@ -2569,7 +2585,7 @@ static void authenticate(ray_dev_t *local)
local
->
authentication_state
=
AWAITING_RESPONSE
;
local
->
authentication_state
=
AWAITING_RESPONSE
;
}
/* end authenticate */
}
/* end authenticate */
/*===========================================================================*/
/*===========================================================================*/
static
void
rx_authenticate
(
ray_dev_t
*
local
,
struct
rcs
*
prcs
,
static
void
rx_authenticate
(
ray_dev_t
*
local
,
struct
rcs
__iomem
*
prcs
,
unsigned
int
pkt_addr
,
int
rx_len
)
unsigned
int
pkt_addr
,
int
rx_len
)
{
{
UCHAR
buff
[
256
];
UCHAR
buff
[
256
];
...
@@ -2614,7 +2630,7 @@ static void rx_authenticate(ray_dev_t *local, struct rcs *prcs,
...
@@ -2614,7 +2630,7 @@ static void rx_authenticate(ray_dev_t *local, struct rcs *prcs,
/*===========================================================================*/
/*===========================================================================*/
static
void
associate
(
ray_dev_t
*
local
)
static
void
associate
(
ray_dev_t
*
local
)
{
{
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
dev_link_t
*
link
=
local
->
finder
;
dev_link_t
*
link
=
local
->
finder
;
struct
net_device
*
dev
=
link
->
priv
;
struct
net_device
*
dev
=
link
->
priv
;
int
ccsindex
;
int
ccsindex
;
...
@@ -2630,7 +2646,7 @@ static void associate(ray_dev_t *local)
...
@@ -2630,7 +2646,7 @@ static void associate(ray_dev_t *local)
return
;
return
;
}
}
DEBUG
(
1
,
"ray_cs Starting association with access point
\n
"
);
DEBUG
(
1
,
"ray_cs Starting association with access point
\n
"
);
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
ccsindex
;
pccs
=
ccs_base
(
local
)
+
ccsindex
;
/* fill in the CCS */
/* fill in the CCS */
writeb
(
CCS_START_ASSOCIATION
,
&
pccs
->
cmd
);
writeb
(
CCS_START_ASSOCIATION
,
&
pccs
->
cmd
);
/* Interrupt the firmware to process the command */
/* Interrupt the firmware to process the command */
...
@@ -2650,7 +2666,7 @@ static void associate(ray_dev_t *local)
...
@@ -2650,7 +2666,7 @@ static void associate(ray_dev_t *local)
}
/* end associate */
}
/* end associate */
/*===========================================================================*/
/*===========================================================================*/
static
void
rx_deauthenticate
(
ray_dev_t
*
local
,
struct
rcs
*
prcs
,
static
void
rx_deauthenticate
(
ray_dev_t
*
local
,
struct
rcs
__iomem
*
prcs
,
unsigned
int
pkt_addr
,
int
rx_len
)
unsigned
int
pkt_addr
,
int
rx_len
)
{
{
/* UCHAR buff[256];
/* UCHAR buff[256];
...
@@ -2798,8 +2814,8 @@ static int ray_cs_proc_read(char *buf, char **start, off_t offset, int len)
...
@@ -2798,8 +2814,8 @@ static int ray_cs_proc_read(char *buf, char **start, off_t offset, int len)
static
int
build_auth_frame
(
ray_dev_t
*
local
,
UCHAR
*
dest
,
int
auth_type
)
static
int
build_auth_frame
(
ray_dev_t
*
local
,
UCHAR
*
dest
,
int
auth_type
)
{
{
int
addr
;
int
addr
;
struct
ccs
*
pccs
;
struct
ccs
__iomem
*
pccs
;
struct
tx_msg
*
ptx
;
struct
tx_msg
__iomem
*
ptx
;
int
ccsindex
;
int
ccsindex
;
/* If no tx buffers available, return */
/* If no tx buffers available, return */
...
@@ -2809,7 +2825,7 @@ static int build_auth_frame(ray_dev_t *local, UCHAR *dest, int auth_type)
...
@@ -2809,7 +2825,7 @@ static int build_auth_frame(ray_dev_t *local, UCHAR *dest, int auth_type)
return
-
1
;
return
-
1
;
}
}
pccs
=
((
struct
ccs
*
)(
local
->
sram
+
CCS_BASE
)
)
+
ccsindex
;
pccs
=
ccs_base
(
local
)
+
ccsindex
;
/* Address in card space */
/* Address in card space */
addr
=
TX_BUF_BASE
+
(
ccsindex
<<
11
);
addr
=
TX_BUF_BASE
+
(
ccsindex
<<
11
);
...
@@ -2821,7 +2837,7 @@ static int build_auth_frame(ray_dev_t *local, UCHAR *dest, int auth_type)
...
@@ -2821,7 +2837,7 @@ static int build_auth_frame(ray_dev_t *local, UCHAR *dest, int auth_type)
writeb
(
TX_AUTHENTICATE_LENGTH_LSB
,
pccs
->
var
.
tx_request
.
tx_data_length
+
1
);
writeb
(
TX_AUTHENTICATE_LENGTH_LSB
,
pccs
->
var
.
tx_request
.
tx_data_length
+
1
);
writeb
(
0
,
&
pccs
->
var
.
tx_request
.
pow_sav_mode
);
writeb
(
0
,
&
pccs
->
var
.
tx_request
.
pow_sav_mode
);
ptx
=
(
struct
tx_msg
*
)(
local
->
sram
+
addr
)
;
ptx
=
local
->
sram
+
addr
;
/* fill in the mac header */
/* fill in the mac header */
writeb
(
PROTOCOL_VER
|
AUTHENTIC_TYPE
,
&
ptx
->
mac
.
frame_ctl_1
);
writeb
(
PROTOCOL_VER
|
AUTHENTIC_TYPE
,
&
ptx
->
mac
.
frame_ctl_1
);
writeb
(
0
,
&
ptx
->
mac
.
frame_ctl_2
);
writeb
(
0
,
&
ptx
->
mac
.
frame_ctl_2
);
...
@@ -2931,15 +2947,6 @@ static void __exit exit_ray_cs(void)
...
@@ -2931,15 +2947,6 @@ static void __exit exit_ray_cs(void)
{
{
DEBUG
(
0
,
"ray_cs: cleanup_module
\n
"
);
DEBUG
(
0
,
"ray_cs: cleanup_module
\n
"
);
#ifdef CONFIG_PROC_FS
remove_proc_entry
(
"ray_cs"
,
proc_root_driver
);
#endif
pcmcia_unregister_driver
(
&
ray_driver
);
while
(
dev_list
!=
NULL
)
ray_detach
(
dev_list
);
#ifdef CONFIG_PROC_FS
#ifdef CONFIG_PROC_FS
remove_proc_entry
(
"driver/ray_cs/ray_cs"
,
NULL
);
remove_proc_entry
(
"driver/ray_cs/ray_cs"
,
NULL
);
remove_proc_entry
(
"driver/ray_cs/essid"
,
NULL
);
remove_proc_entry
(
"driver/ray_cs/essid"
,
NULL
);
...
@@ -2947,6 +2954,10 @@ static void __exit exit_ray_cs(void)
...
@@ -2947,6 +2954,10 @@ static void __exit exit_ray_cs(void)
remove_proc_entry
(
"driver/ray_cs/translate"
,
NULL
);
remove_proc_entry
(
"driver/ray_cs/translate"
,
NULL
);
remove_proc_entry
(
"driver/ray_cs"
,
NULL
);
remove_proc_entry
(
"driver/ray_cs"
,
NULL
);
#endif
#endif
pcmcia_unregister_driver
(
&
ray_driver
);
while
(
dev_list
!=
NULL
)
ray_detach
(
dev_list
);
}
/* exit_ray_cs */
}
/* exit_ray_cs */
module_init
(
init_ray_cs
);
module_init
(
init_ray_cs
);
...
...
drivers/net/wireless/ray_cs.h
View file @
6c2447fd
...
@@ -28,9 +28,9 @@ typedef struct ray_dev_t {
...
@@ -28,9 +28,9 @@ typedef struct ray_dev_t {
dev_node_t
node
;
dev_node_t
node
;
window_handle_t
amem_handle
;
/* handle to window for attribute memory */
window_handle_t
amem_handle
;
/* handle to window for attribute memory */
window_handle_t
rmem_handle
;
/* handle to window for rx buffer on card */
window_handle_t
rmem_handle
;
/* handle to window for rx buffer on card */
UCHAR
*
sram
;
/* pointer to beginning of shared RAM */
void
__iomem
*
sram
;
/* pointer to beginning of shared RAM */
UCHAR
*
amem
;
/* pointer to attribute mem window */
void
__iomem
*
amem
;
/* pointer to attribute mem window */
UCHAR
*
rmem
;
/* pointer to receive buffer window */
void
__iomem
*
rmem
;
/* pointer to receive buffer window */
dev_link_t
*
finder
;
/* pointer back to dev_link_t for card */
dev_link_t
*
finder
;
/* pointer back to dev_link_t for card */
struct
timer_list
timer
;
struct
timer_list
timer
;
long
tx_ccs_lock
;
long
tx_ccs_lock
;
...
...
include/asm-arm/page.h
View file @
6c2447fd
...
@@ -133,7 +133,7 @@ extern void __cpu_copy_user_page(void *to, const void *from,
...
@@ -133,7 +133,7 @@ extern void __cpu_copy_user_page(void *to, const void *from,
} while (0)
} while (0)
#define clear_page(page) memzero((void *)(page), PAGE_SIZE)
#define clear_page(page) memzero((void *)(page), PAGE_SIZE)
extern
void
copy_page
(
void
*
to
,
void
*
from
);
extern
void
copy_page
(
void
*
to
,
const
void
*
from
);
#undef STRICT_MM_TYPECHECKS
#undef STRICT_MM_TYPECHECKS
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment