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
c4cbb34b
Commit
c4cbb34b
authored
Apr 15, 2008
by
David S. Miller
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/linville/wireless-2.6
parents
0517deed
b358492c
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
108 additions
and
79 deletions
+108
-79
MAINTAINERS
MAINTAINERS
+9
-1
drivers/net/b44.c
drivers/net/b44.c
+26
-26
drivers/net/ps3_gelic_wireless.c
drivers/net/ps3_gelic_wireless.c
+8
-3
drivers/net/wireless/b43/dma.c
drivers/net/wireless/b43/dma.c
+14
-13
drivers/net/wireless/b43legacy/dma.c
drivers/net/wireless/b43legacy/dma.c
+31
-24
drivers/net/wireless/b43legacy/main.c
drivers/net/wireless/b43legacy/main.c
+2
-0
drivers/net/wireless/rtl8187_dev.c
drivers/net/wireless/rtl8187_dev.c
+3
-0
drivers/ssb/main.c
drivers/ssb/main.c
+8
-6
include/linux/ssb/ssb.h
include/linux/ssb/ssb.h
+4
-0
net/mac80211/rx.c
net/mac80211/rx.c
+2
-5
net/rfkill/rfkill.c
net/rfkill/rfkill.c
+1
-1
No files found.
MAINTAINERS
View file @
c4cbb34b
...
...
@@ -2116,7 +2116,7 @@ M: reinette.chatre@intel.com
L: linux-wireless@vger.kernel.org
L: ipw3945-devel@lists.sourceforge.net
W: http://intellinuxwireless.org
T: git
git://git.kernel.org/pub/scm/linux/kernel/git/rchatre
/iwlwifi-2.6.git
T: git
kernel.org:/pub/scm/linux/kernel/git/iwlwifi
/iwlwifi-2.6.git
S: Supported
IOC3 ETHERNET DRIVER
...
...
@@ -3280,6 +3280,7 @@ L: linux-wireless@vger.kernel.org
L: rt2400-devel@lists.sourceforge.net
W: http://rt2x00.serialmonkey.com/
S: Maintained
T: git kernel.org:/pub/scm/linux/kernel/git/ivd/rt2x00.git
F: drivers/net/wireless/rt2x00/
RAMDISK RAM BLOCK DEVICE DRIVER
...
...
@@ -3342,6 +3343,13 @@ L: reiserfs-devel@vger.kernel.org
W: http://www.namesys.com
S: Supported
RFKILL
P: Ivo van Doorn
M: IvDoorn@gmail.com
L: netdev@vger.kernel.org
S: Maintained
F: net/rfkill
ROCKETPORT DRIVER
P: Comtrol Corp.
W: http://www.comtrol.com
...
...
drivers/net/b44.c
View file @
c4cbb34b
...
...
@@ -148,7 +148,7 @@ static inline void b44_sync_dma_desc_for_device(struct ssb_device *sdev,
unsigned
long
offset
,
enum
dma_data_direction
dir
)
{
dma_sync_single_range_for_device
(
sdev
->
dev
,
dma_base
,
dma_sync_single_range_for_device
(
sdev
->
d
ma_d
ev
,
dma_base
,
offset
&
dma_desc_align_mask
,
dma_desc_sync_size
,
dir
);
}
...
...
@@ -158,7 +158,7 @@ static inline void b44_sync_dma_desc_for_cpu(struct ssb_device *sdev,
unsigned
long
offset
,
enum
dma_data_direction
dir
)
{
dma_sync_single_range_for_cpu
(
sdev
->
dev
,
dma_base
,
dma_sync_single_range_for_cpu
(
sdev
->
d
ma_d
ev
,
dma_base
,
offset
&
dma_desc_align_mask
,
dma_desc_sync_size
,
dir
);
}
...
...
@@ -613,7 +613,7 @@ static void b44_tx(struct b44 *bp)
BUG_ON
(
skb
==
NULL
);
dma_unmap_single
(
bp
->
sdev
->
dev
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
rp
->
mapping
,
skb
->
len
,
DMA_TO_DEVICE
);
...
...
@@ -653,7 +653,7 @@ static int b44_alloc_rx_skb(struct b44 *bp, int src_idx, u32 dest_idx_unmasked)
if
(
skb
==
NULL
)
return
-
ENOMEM
;
mapping
=
dma_map_single
(
bp
->
sdev
->
dev
,
skb
->
data
,
mapping
=
dma_map_single
(
bp
->
sdev
->
d
ma_d
ev
,
skb
->
data
,
RX_PKT_BUF_SZ
,
DMA_FROM_DEVICE
);
...
...
@@ -663,19 +663,19 @@ static int b44_alloc_rx_skb(struct b44 *bp, int src_idx, u32 dest_idx_unmasked)
mapping
+
RX_PKT_BUF_SZ
>
DMA_30BIT_MASK
)
{
/* Sigh... */
if
(
!
dma_mapping_error
(
mapping
))
dma_unmap_single
(
bp
->
sdev
->
dev
,
mapping
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
mapping
,
RX_PKT_BUF_SZ
,
DMA_FROM_DEVICE
);
dev_kfree_skb_any
(
skb
);
skb
=
__netdev_alloc_skb
(
bp
->
dev
,
RX_PKT_BUF_SZ
,
GFP_ATOMIC
|
GFP_DMA
);
if
(
skb
==
NULL
)
return
-
ENOMEM
;
mapping
=
dma_map_single
(
bp
->
sdev
->
dev
,
skb
->
data
,
mapping
=
dma_map_single
(
bp
->
sdev
->
d
ma_d
ev
,
skb
->
data
,
RX_PKT_BUF_SZ
,
DMA_FROM_DEVICE
);
if
(
dma_mapping_error
(
mapping
)
||
mapping
+
RX_PKT_BUF_SZ
>
DMA_30BIT_MASK
)
{
if
(
!
dma_mapping_error
(
mapping
))
dma_unmap_single
(
bp
->
sdev
->
dev
,
mapping
,
RX_PKT_BUF_SZ
,
DMA_FROM_DEVICE
);
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
mapping
,
RX_PKT_BUF_SZ
,
DMA_FROM_DEVICE
);
dev_kfree_skb_any
(
skb
);
return
-
ENOMEM
;
}
...
...
@@ -750,7 +750,7 @@ static void b44_recycle_rx(struct b44 *bp, int src_idx, u32 dest_idx_unmasked)
dest_idx
*
sizeof
(
dest_desc
),
DMA_BIDIRECTIONAL
);
dma_sync_single_for_device
(
bp
->
sdev
->
dev
,
le32_to_cpu
(
src_desc
->
addr
),
dma_sync_single_for_device
(
bp
->
sdev
->
d
ma_d
ev
,
le32_to_cpu
(
src_desc
->
addr
),
RX_PKT_BUF_SZ
,
DMA_FROM_DEVICE
);
}
...
...
@@ -772,7 +772,7 @@ static int b44_rx(struct b44 *bp, int budget)
struct
rx_header
*
rh
;
u16
len
;
dma_sync_single_for_cpu
(
bp
->
sdev
->
dev
,
map
,
dma_sync_single_for_cpu
(
bp
->
sdev
->
d
ma_d
ev
,
map
,
RX_PKT_BUF_SZ
,
DMA_FROM_DEVICE
);
rh
=
(
struct
rx_header
*
)
skb
->
data
;
...
...
@@ -806,7 +806,7 @@ static int b44_rx(struct b44 *bp, int budget)
skb_size
=
b44_alloc_rx_skb
(
bp
,
cons
,
bp
->
rx_prod
);
if
(
skb_size
<
0
)
goto
drop_it
;
dma_unmap_single
(
bp
->
sdev
->
dev
,
map
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
map
,
skb_size
,
DMA_FROM_DEVICE
);
/* Leave out rx_header */
skb_put
(
skb
,
len
+
RX_PKT_OFFSET
);
...
...
@@ -966,24 +966,24 @@ static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev)
goto
err_out
;
}
mapping
=
dma_map_single
(
bp
->
sdev
->
dev
,
skb
->
data
,
len
,
DMA_TO_DEVICE
);
mapping
=
dma_map_single
(
bp
->
sdev
->
d
ma_d
ev
,
skb
->
data
,
len
,
DMA_TO_DEVICE
);
if
(
dma_mapping_error
(
mapping
)
||
mapping
+
len
>
DMA_30BIT_MASK
)
{
struct
sk_buff
*
bounce_skb
;
/* Chip can't handle DMA to/from >1GB, use bounce buffer */
if
(
!
dma_mapping_error
(
mapping
))
dma_unmap_single
(
bp
->
sdev
->
dev
,
mapping
,
len
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
mapping
,
len
,
DMA_TO_DEVICE
);
bounce_skb
=
__dev_alloc_skb
(
len
,
GFP_ATOMIC
|
GFP_DMA
);
if
(
!
bounce_skb
)
goto
err_out
;
mapping
=
dma_map_single
(
bp
->
sdev
->
dev
,
bounce_skb
->
data
,
mapping
=
dma_map_single
(
bp
->
sdev
->
d
ma_d
ev
,
bounce_skb
->
data
,
len
,
DMA_TO_DEVICE
);
if
(
dma_mapping_error
(
mapping
)
||
mapping
+
len
>
DMA_30BIT_MASK
)
{
if
(
!
dma_mapping_error
(
mapping
))
dma_unmap_single
(
bp
->
sdev
->
dev
,
mapping
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
mapping
,
len
,
DMA_TO_DEVICE
);
dev_kfree_skb_any
(
bounce_skb
);
goto
err_out
;
...
...
@@ -1082,7 +1082,7 @@ static void b44_free_rings(struct b44 *bp)
if
(
rp
->
skb
==
NULL
)
continue
;
dma_unmap_single
(
bp
->
sdev
->
dev
,
rp
->
mapping
,
RX_PKT_BUF_SZ
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
rp
->
mapping
,
RX_PKT_BUF_SZ
,
DMA_FROM_DEVICE
);
dev_kfree_skb_any
(
rp
->
skb
);
rp
->
skb
=
NULL
;
...
...
@@ -1094,7 +1094,7 @@ static void b44_free_rings(struct b44 *bp)
if
(
rp
->
skb
==
NULL
)
continue
;
dma_unmap_single
(
bp
->
sdev
->
dev
,
rp
->
mapping
,
rp
->
skb
->
len
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
rp
->
mapping
,
rp
->
skb
->
len
,
DMA_TO_DEVICE
);
dev_kfree_skb_any
(
rp
->
skb
);
rp
->
skb
=
NULL
;
...
...
@@ -1117,12 +1117,12 @@ static void b44_init_rings(struct b44 *bp)
memset
(
bp
->
tx_ring
,
0
,
B44_TX_RING_BYTES
);
if
(
bp
->
flags
&
B44_FLAG_RX_RING_HACK
)
dma_sync_single_for_device
(
bp
->
sdev
->
dev
,
bp
->
rx_ring_dma
,
dma_sync_single_for_device
(
bp
->
sdev
->
d
ma_d
ev
,
bp
->
rx_ring_dma
,
DMA_TABLE_BYTES
,
DMA_BIDIRECTIONAL
);
if
(
bp
->
flags
&
B44_FLAG_TX_RING_HACK
)
dma_sync_single_for_device
(
bp
->
sdev
->
dev
,
bp
->
tx_ring_dma
,
dma_sync_single_for_device
(
bp
->
sdev
->
d
ma_d
ev
,
bp
->
tx_ring_dma
,
DMA_TABLE_BYTES
,
DMA_TO_DEVICE
);
...
...
@@ -1144,24 +1144,24 @@ static void b44_free_consistent(struct b44 *bp)
bp
->
tx_buffers
=
NULL
;
if
(
bp
->
rx_ring
)
{
if
(
bp
->
flags
&
B44_FLAG_RX_RING_HACK
)
{
dma_unmap_single
(
bp
->
sdev
->
dev
,
bp
->
rx_ring_dma
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
bp
->
rx_ring_dma
,
DMA_TABLE_BYTES
,
DMA_BIDIRECTIONAL
);
kfree
(
bp
->
rx_ring
);
}
else
dma_free_coherent
(
bp
->
sdev
->
dev
,
DMA_TABLE_BYTES
,
dma_free_coherent
(
bp
->
sdev
->
d
ma_d
ev
,
DMA_TABLE_BYTES
,
bp
->
rx_ring
,
bp
->
rx_ring_dma
);
bp
->
rx_ring
=
NULL
;
bp
->
flags
&=
~
B44_FLAG_RX_RING_HACK
;
}
if
(
bp
->
tx_ring
)
{
if
(
bp
->
flags
&
B44_FLAG_TX_RING_HACK
)
{
dma_unmap_single
(
bp
->
sdev
->
dev
,
bp
->
tx_ring_dma
,
dma_unmap_single
(
bp
->
sdev
->
d
ma_d
ev
,
bp
->
tx_ring_dma
,
DMA_TABLE_BYTES
,
DMA_TO_DEVICE
);
kfree
(
bp
->
tx_ring
);
}
else
dma_free_coherent
(
bp
->
sdev
->
dev
,
DMA_TABLE_BYTES
,
dma_free_coherent
(
bp
->
sdev
->
d
ma_d
ev
,
DMA_TABLE_BYTES
,
bp
->
tx_ring
,
bp
->
tx_ring_dma
);
bp
->
tx_ring
=
NULL
;
bp
->
flags
&=
~
B44_FLAG_TX_RING_HACK
;
...
...
@@ -1187,7 +1187,7 @@ static int b44_alloc_consistent(struct b44 *bp, gfp_t gfp)
goto
out_err
;
size
=
DMA_TABLE_BYTES
;
bp
->
rx_ring
=
dma_alloc_coherent
(
bp
->
sdev
->
dev
,
size
,
&
bp
->
rx_ring_dma
,
gfp
);
bp
->
rx_ring
=
dma_alloc_coherent
(
bp
->
sdev
->
d
ma_d
ev
,
size
,
&
bp
->
rx_ring_dma
,
gfp
);
if
(
!
bp
->
rx_ring
)
{
/* Allocation may have failed due to pci_alloc_consistent
insisting on use of GFP_DMA, which is more restrictive
...
...
@@ -1199,7 +1199,7 @@ static int b44_alloc_consistent(struct b44 *bp, gfp_t gfp)
if
(
!
rx_ring
)
goto
out_err
;
rx_ring_dma
=
dma_map_single
(
bp
->
sdev
->
dev
,
rx_ring
,
rx_ring_dma
=
dma_map_single
(
bp
->
sdev
->
d
ma_d
ev
,
rx_ring
,
DMA_TABLE_BYTES
,
DMA_BIDIRECTIONAL
);
...
...
@@ -1214,7 +1214,7 @@ static int b44_alloc_consistent(struct b44 *bp, gfp_t gfp)
bp
->
flags
|=
B44_FLAG_RX_RING_HACK
;
}
bp
->
tx_ring
=
dma_alloc_coherent
(
bp
->
sdev
->
dev
,
size
,
&
bp
->
tx_ring_dma
,
gfp
);
bp
->
tx_ring
=
dma_alloc_coherent
(
bp
->
sdev
->
d
ma_d
ev
,
size
,
&
bp
->
tx_ring_dma
,
gfp
);
if
(
!
bp
->
tx_ring
)
{
/* Allocation may have failed due to dma_alloc_coherent
insisting on use of GFP_DMA, which is more restrictive
...
...
@@ -1226,7 +1226,7 @@ static int b44_alloc_consistent(struct b44 *bp, gfp_t gfp)
if
(
!
tx_ring
)
goto
out_err
;
tx_ring_dma
=
dma_map_single
(
bp
->
sdev
->
dev
,
tx_ring
,
tx_ring_dma
=
dma_map_single
(
bp
->
sdev
->
d
ma_d
ev
,
tx_ring
,
DMA_TABLE_BYTES
,
DMA_TO_DEVICE
);
...
...
drivers/net/ps3_gelic_wireless.c
View file @
c4cbb34b
...
...
@@ -512,13 +512,18 @@ static void gelic_wl_parse_ie(u8 *data, size_t len,
data
,
len
);
memset
(
ie_info
,
0
,
sizeof
(
struct
ie_info
));
while
(
0
<
data_left
)
{
while
(
2
<=
data_left
)
{
item_id
=
*
pos
++
;
item_len
=
*
pos
++
;
data_left
-=
2
;
if
(
data_left
<
item_len
)
break
;
switch
(
item_id
)
{
case
MFIE_TYPE_GENERIC
:
if
(
!
memcmp
(
pos
,
wpa_oui
,
OUI_LEN
)
&&
if
((
OUI_LEN
+
1
<=
item_len
)
&&
!
memcmp
(
pos
,
wpa_oui
,
OUI_LEN
)
&&
pos
[
OUI_LEN
]
==
0x01
)
{
ie_info
->
wpa
.
data
=
pos
-
2
;
ie_info
->
wpa
.
len
=
item_len
+
2
;
...
...
@@ -535,7 +540,7 @@ static void gelic_wl_parse_ie(u8 *data, size_t len,
break
;
}
pos
+=
item_len
;
data_left
-=
item_len
+
2
;
data_left
-=
item_len
;
}
pr_debug
(
"%s: wpa=%p,%d wpa2=%p,%d
\n
"
,
__func__
,
ie_info
->
wpa
.
data
,
ie_info
->
wpa
.
len
,
...
...
drivers/net/wireless/b43/dma.c
View file @
c4cbb34b
...
...
@@ -373,10 +373,10 @@ static inline
dma_addr_t
dmaaddr
;
if
(
tx
)
{
dmaaddr
=
dma_map_single
(
ring
->
dev
->
dev
->
dev
,
dmaaddr
=
dma_map_single
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
buf
,
len
,
DMA_TO_DEVICE
);
}
else
{
dmaaddr
=
dma_map_single
(
ring
->
dev
->
dev
->
dev
,
dmaaddr
=
dma_map_single
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
buf
,
len
,
DMA_FROM_DEVICE
);
}
...
...
@@ -388,9 +388,10 @@ static inline
dma_addr_t
addr
,
size_t
len
,
int
tx
)
{
if
(
tx
)
{
dma_unmap_single
(
ring
->
dev
->
dev
->
dev
,
addr
,
len
,
DMA_TO_DEVICE
);
dma_unmap_single
(
ring
->
dev
->
dev
->
dma_dev
,
addr
,
len
,
DMA_TO_DEVICE
);
}
else
{
dma_unmap_single
(
ring
->
dev
->
dev
->
dev
,
dma_unmap_single
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
addr
,
len
,
DMA_FROM_DEVICE
);
}
}
...
...
@@ -400,7 +401,7 @@ static inline
dma_addr_t
addr
,
size_t
len
)
{
B43_WARN_ON
(
ring
->
tx
);
dma_sync_single_for_cpu
(
ring
->
dev
->
dev
->
dev
,
dma_sync_single_for_cpu
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
addr
,
len
,
DMA_FROM_DEVICE
);
}
...
...
@@ -409,7 +410,7 @@ static inline
dma_addr_t
addr
,
size_t
len
)
{
B43_WARN_ON
(
ring
->
tx
);
dma_sync_single_for_device
(
ring
->
dev
->
dev
->
dev
,
dma_sync_single_for_device
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
addr
,
len
,
DMA_FROM_DEVICE
);
}
...
...
@@ -425,7 +426,7 @@ static inline
static
int
alloc_ringmemory
(
struct
b43_dmaring
*
ring
)
{
struct
device
*
d
ev
=
ring
->
dev
->
dev
->
dev
;
struct
device
*
d
ma_dev
=
ring
->
dev
->
dev
->
dma_
dev
;
gfp_t
flags
=
GFP_KERNEL
;
/* The specs call for 4K buffers for 30- and 32-bit DMA with 4K
...
...
@@ -439,7 +440,7 @@ static int alloc_ringmemory(struct b43_dmaring *ring)
*/
if
(
ring
->
type
==
B43_DMA_64BIT
)
flags
|=
GFP_DMA
;
ring
->
descbase
=
dma_alloc_coherent
(
dev
,
B43_DMA_RINGMEMSIZE
,
ring
->
descbase
=
dma_alloc_coherent
(
d
ma_d
ev
,
B43_DMA_RINGMEMSIZE
,
&
(
ring
->
dmabase
),
flags
);
if
(
!
ring
->
descbase
)
{
b43err
(
ring
->
dev
->
wl
,
"DMA ringmemory allocation failed
\n
"
);
...
...
@@ -452,9 +453,9 @@ static int alloc_ringmemory(struct b43_dmaring *ring)
static
void
free_ringmemory
(
struct
b43_dmaring
*
ring
)
{
struct
device
*
d
ev
=
ring
->
dev
->
dev
->
dev
;
struct
device
*
d
ma_dev
=
ring
->
dev
->
dev
->
dma_
dev
;
dma_free_coherent
(
dev
,
B43_DMA_RINGMEMSIZE
,
dma_free_coherent
(
d
ma_d
ev
,
B43_DMA_RINGMEMSIZE
,
ring
->
descbase
,
ring
->
dmabase
);
}
...
...
@@ -854,7 +855,7 @@ struct b43_dmaring *b43_setup_dmaring(struct b43_wldev *dev,
goto
err_kfree_meta
;
/* test for ability to dma to txhdr_cache */
dma_test
=
dma_map_single
(
dev
->
dev
->
dev
,
dma_test
=
dma_map_single
(
dev
->
dev
->
d
ma_d
ev
,
ring
->
txhdr_cache
,
b43_txhdr_size
(
dev
),
DMA_TO_DEVICE
);
...
...
@@ -869,7 +870,7 @@ struct b43_dmaring *b43_setup_dmaring(struct b43_wldev *dev,
if
(
!
ring
->
txhdr_cache
)
goto
err_kfree_meta
;
dma_test
=
dma_map_single
(
dev
->
dev
->
dev
,
dma_test
=
dma_map_single
(
dev
->
dev
->
d
ma_d
ev
,
ring
->
txhdr_cache
,
b43_txhdr_size
(
dev
),
DMA_TO_DEVICE
);
...
...
@@ -883,7 +884,7 @@ struct b43_dmaring *b43_setup_dmaring(struct b43_wldev *dev,
}
}
dma_unmap_single
(
dev
->
dev
->
dev
,
dma_unmap_single
(
dev
->
dev
->
d
ma_d
ev
,
dma_test
,
b43_txhdr_size
(
dev
),
DMA_TO_DEVICE
);
}
...
...
drivers/net/wireless/b43legacy/dma.c
View file @
c4cbb34b
...
...
@@ -393,11 +393,11 @@ dma_addr_t map_descbuffer(struct b43legacy_dmaring *ring,
dma_addr_t
dmaaddr
;
if
(
tx
)
dmaaddr
=
dma_map_single
(
ring
->
dev
->
dev
->
dev
,
dmaaddr
=
dma_map_single
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
buf
,
len
,
DMA_TO_DEVICE
);
else
dmaaddr
=
dma_map_single
(
ring
->
dev
->
dev
->
dev
,
dmaaddr
=
dma_map_single
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
buf
,
len
,
DMA_FROM_DEVICE
);
...
...
@@ -411,11 +411,11 @@ void unmap_descbuffer(struct b43legacy_dmaring *ring,
int
tx
)
{
if
(
tx
)
dma_unmap_single
(
ring
->
dev
->
dev
->
dev
,
dma_unmap_single
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
addr
,
len
,
DMA_TO_DEVICE
);
else
dma_unmap_single
(
ring
->
dev
->
dev
->
dev
,
dma_unmap_single
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
addr
,
len
,
DMA_FROM_DEVICE
);
}
...
...
@@ -427,7 +427,7 @@ void sync_descbuffer_for_cpu(struct b43legacy_dmaring *ring,
{
B43legacy_WARN_ON
(
ring
->
tx
);
dma_sync_single_for_cpu
(
ring
->
dev
->
dev
->
dev
,
dma_sync_single_for_cpu
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
addr
,
len
,
DMA_FROM_DEVICE
);
}
...
...
@@ -438,7 +438,7 @@ void sync_descbuffer_for_device(struct b43legacy_dmaring *ring,
{
B43legacy_WARN_ON
(
ring
->
tx
);
dma_sync_single_for_device
(
ring
->
dev
->
dev
->
dev
,
dma_sync_single_for_device
(
ring
->
dev
->
dev
->
d
ma_d
ev
,
addr
,
len
,
DMA_FROM_DEVICE
);
}
...
...
@@ -458,9 +458,9 @@ void free_descriptor_buffer(struct b43legacy_dmaring *ring,
static
int
alloc_ringmemory
(
struct
b43legacy_dmaring
*
ring
)
{
struct
device
*
d
ev
=
ring
->
dev
->
dev
->
dev
;
struct
device
*
d
ma_dev
=
ring
->
dev
->
dev
->
dma_
dev
;
ring
->
descbase
=
dma_alloc_coherent
(
dev
,
B43legacy_DMA_RINGMEMSIZE
,
ring
->
descbase
=
dma_alloc_coherent
(
d
ma_d
ev
,
B43legacy_DMA_RINGMEMSIZE
,
&
(
ring
->
dmabase
),
GFP_KERNEL
);
if
(
!
ring
->
descbase
)
{
b43legacyerr
(
ring
->
dev
->
wl
,
"DMA ringmemory allocation"
...
...
@@ -474,9 +474,9 @@ static int alloc_ringmemory(struct b43legacy_dmaring *ring)
static
void
free_ringmemory
(
struct
b43legacy_dmaring
*
ring
)
{
struct
device
*
d
ev
=
ring
->
dev
->
dev
->
dev
;
struct
device
*
d
ma_dev
=
ring
->
dev
->
dev
->
dma_
dev
;
dma_free_coherent
(
dev
,
B43legacy_DMA_RINGMEMSIZE
,
dma_free_coherent
(
d
ma_d
ev
,
B43legacy_DMA_RINGMEMSIZE
,
ring
->
descbase
,
ring
->
dmabase
);
}
...
...
@@ -585,8 +585,9 @@ static int b43legacy_dmacontroller_tx_reset(struct b43legacy_wldev *dev,
/* Check if a DMA mapping address is invalid. */
static
bool
b43legacy_dma_mapping_error
(
struct
b43legacy_dmaring
*
ring
,
dma_addr_t
addr
,
size_t
buffersize
)
dma_addr_t
addr
,
size_t
buffersize
,
bool
dma_to_device
)
{
if
(
unlikely
(
dma_mapping_error
(
addr
)))
return
1
;
...
...
@@ -594,11 +595,11 @@ static bool b43legacy_dma_mapping_error(struct b43legacy_dmaring *ring,
switch
(
ring
->
type
)
{
case
B43legacy_DMA_30BIT
:
if
((
u64
)
addr
+
buffersize
>
(
1ULL
<<
30
))
return
1
;
goto
address_error
;
break
;
case
B43legacy_DMA_32BIT
:
if
((
u64
)
addr
+
buffersize
>
(
1ULL
<<
32
))
return
1
;
goto
address_error
;
break
;
case
B43legacy_DMA_64BIT
:
/* Currently we can't have addresses beyond 64 bits in the kernel. */
...
...
@@ -607,6 +608,12 @@ static bool b43legacy_dma_mapping_error(struct b43legacy_dmaring *ring,
/* The address is OK. */
return
0
;
address_error:
/* We can't support this address. Unmap it again. */
unmap_descbuffer
(
ring
,
addr
,
buffersize
,
dma_to_device
);
return
1
;
}
static
int
setup_rx_descbuffer
(
struct
b43legacy_dmaring
*
ring
,
...
...
@@ -626,7 +633,7 @@ static int setup_rx_descbuffer(struct b43legacy_dmaring *ring,
return
-
ENOMEM
;
dmaaddr
=
map_descbuffer
(
ring
,
skb
->
data
,
ring
->
rx_buffersize
,
0
);
if
(
b43legacy_dma_mapping_error
(
ring
,
dmaaddr
,
ring
->
rx_buffersize
))
{
if
(
b43legacy_dma_mapping_error
(
ring
,
dmaaddr
,
ring
->
rx_buffersize
,
0
))
{
/* ugh. try to realloc in zone_dma */
gfp_flags
|=
GFP_DMA
;
...
...
@@ -639,7 +646,7 @@ static int setup_rx_descbuffer(struct b43legacy_dmaring *ring,
ring
->
rx_buffersize
,
0
);
}
if
(
b43legacy_dma_mapping_error
(
ring
,
dmaaddr
,
ring
->
rx_buffersize
))
{
if
(
b43legacy_dma_mapping_error
(
ring
,
dmaaddr
,
ring
->
rx_buffersize
,
0
))
{
dev_kfree_skb_any
(
skb
);
return
-
EIO
;
}
...
...
@@ -886,12 +893,12 @@ struct b43legacy_dmaring *b43legacy_setup_dmaring(struct b43legacy_wldev *dev,
goto
err_kfree_meta
;
/* test for ability to dma to txhdr_cache */
dma_test
=
dma_map_single
(
dev
->
dev
->
dev
,
ring
->
txhdr_cache
,
dma_test
=
dma_map_single
(
dev
->
dev
->
d
ma_d
ev
,
ring
->
txhdr_cache
,
sizeof
(
struct
b43legacy_txhdr_fw3
),
DMA_TO_DEVICE
);
if
(
b43legacy_dma_mapping_error
(
ring
,
dma_test
,
sizeof
(
struct
b43legacy_txhdr_fw3
)))
{
sizeof
(
struct
b43legacy_txhdr_fw3
)
,
1
))
{
/* ugh realloc */
kfree
(
ring
->
txhdr_cache
);
ring
->
txhdr_cache
=
kcalloc
(
nr_slots
,
...
...
@@ -900,17 +907,17 @@ struct b43legacy_dmaring *b43legacy_setup_dmaring(struct b43legacy_wldev *dev,
if
(
!
ring
->
txhdr_cache
)
goto
err_kfree_meta
;
dma_test
=
dma_map_single
(
dev
->
dev
->
dev
,
dma_test
=
dma_map_single
(
dev
->
dev
->
d
ma_d
ev
,
ring
->
txhdr_cache
,
sizeof
(
struct
b43legacy_txhdr_fw3
),
DMA_TO_DEVICE
);
if
(
b43legacy_dma_mapping_error
(
ring
,
dma_test
,
sizeof
(
struct
b43legacy_txhdr_fw3
)))
sizeof
(
struct
b43legacy_txhdr_fw3
)
,
1
))
goto
err_kfree_txhdr_cache
;
}
dma_unmap_single
(
dev
->
dev
->
dev
,
dma_unmap_single
(
dev
->
dev
->
d
ma_d
ev
,
dma_test
,
sizeof
(
struct
b43legacy_txhdr_fw3
),
DMA_TO_DEVICE
);
}
...
...
@@ -1235,7 +1242,7 @@ static int dma_tx_fragment(struct b43legacy_dmaring *ring,
meta_hdr
->
dmaaddr
=
map_descbuffer
(
ring
,
(
unsigned
char
*
)
header
,
sizeof
(
struct
b43legacy_txhdr_fw3
),
1
);
if
(
b43legacy_dma_mapping_error
(
ring
,
meta_hdr
->
dmaaddr
,
sizeof
(
struct
b43legacy_txhdr_fw3
)))
{
sizeof
(
struct
b43legacy_txhdr_fw3
)
,
1
))
{
ring
->
current_slot
=
old_top_slot
;
ring
->
used_slots
=
old_used_slots
;
return
-
EIO
;
...
...
@@ -1254,7 +1261,7 @@ static int dma_tx_fragment(struct b43legacy_dmaring *ring,
meta
->
dmaaddr
=
map_descbuffer
(
ring
,
skb
->
data
,
skb
->
len
,
1
);
/* create a bounce buffer in zone_dma on mapping failure. */
if
(
b43legacy_dma_mapping_error
(
ring
,
meta
->
dmaaddr
,
skb
->
len
))
{
if
(
b43legacy_dma_mapping_error
(
ring
,
meta
->
dmaaddr
,
skb
->
len
,
1
))
{
bounce_skb
=
__dev_alloc_skb
(
skb
->
len
,
GFP_ATOMIC
|
GFP_DMA
);
if
(
!
bounce_skb
)
{
ring
->
current_slot
=
old_top_slot
;
...
...
@@ -1268,7 +1275,7 @@ static int dma_tx_fragment(struct b43legacy_dmaring *ring,
skb
=
bounce_skb
;
meta
->
skb
=
skb
;
meta
->
dmaaddr
=
map_descbuffer
(
ring
,
skb
->
data
,
skb
->
len
,
1
);
if
(
b43legacy_dma_mapping_error
(
ring
,
meta
->
dmaaddr
,
skb
->
len
))
{
if
(
b43legacy_dma_mapping_error
(
ring
,
meta
->
dmaaddr
,
skb
->
len
,
1
))
{
ring
->
current_slot
=
old_top_slot
;
ring
->
used_slots
=
old_used_slots
;
err
=
-
EIO
;
...
...
drivers/net/wireless/b43legacy/main.c
View file @
c4cbb34b
...
...
@@ -1488,6 +1488,7 @@ static int b43legacy_request_firmware(struct b43legacy_wldev *dev)
}
if
(
!
fw
->
initvals
)
{
switch
(
dev
->
phy
.
type
)
{
case
B43legacy_PHYTYPE_B
:
case
B43legacy_PHYTYPE_G
:
if
((
rev
>=
5
)
&&
(
rev
<=
10
))
filename
=
"b0g0initvals5"
;
...
...
@@ -1505,6 +1506,7 @@ static int b43legacy_request_firmware(struct b43legacy_wldev *dev)
}
if
(
!
fw
->
initvals_band
)
{
switch
(
dev
->
phy
.
type
)
{
case
B43legacy_PHYTYPE_B
:
case
B43legacy_PHYTYPE_G
:
if
((
rev
>=
5
)
&&
(
rev
<=
10
))
filename
=
"b0g0bsinitvals5"
;
...
...
drivers/net/wireless/rtl8187_dev.c
View file @
c4cbb34b
...
...
@@ -509,6 +509,8 @@ static int rtl8187_add_interface(struct ieee80211_hw *dev,
return
-
EOPNOTSUPP
;
}
priv
->
vif
=
conf
->
vif
;
rtl818x_iowrite8
(
priv
,
&
priv
->
map
->
EEPROM_CMD
,
RTL818X_EEPROM_CMD_CONFIG
);
for
(
i
=
0
;
i
<
ETH_ALEN
;
i
++
)
rtl818x_iowrite8
(
priv
,
&
priv
->
map
->
MAC
[
i
],
...
...
@@ -523,6 +525,7 @@ static void rtl8187_remove_interface(struct ieee80211_hw *dev,
{
struct
rtl8187_priv
*
priv
=
dev
->
priv
;
priv
->
mode
=
IEEE80211_IF_TYPE_MNTR
;
priv
->
vif
=
NULL
;
}
static
int
rtl8187_config
(
struct
ieee80211_hw
*
dev
,
struct
ieee80211_conf
*
conf
)
...
...
drivers/ssb/main.c
View file @
c4cbb34b
...
...
@@ -436,15 +436,18 @@ static int ssb_devices_register(struct ssb_bus *bus)
#ifdef CONFIG_SSB_PCIHOST
sdev
->
irq
=
bus
->
host_pci
->
irq
;
dev
->
parent
=
&
bus
->
host_pci
->
dev
;
sdev
->
dma_dev
=
&
bus
->
host_pci
->
dev
;
#endif
break
;
case
SSB_BUSTYPE_PCMCIA
:
#ifdef CONFIG_SSB_PCMCIAHOST
sdev
->
irq
=
bus
->
host_pcmcia
->
irq
.
AssignedIRQ
;
dev
->
parent
=
&
bus
->
host_pcmcia
->
dev
;
sdev
->
dma_dev
=
&
bus
->
host_pcmcia
->
dev
;
#endif
break
;
case
SSB_BUSTYPE_SSB
:
sdev
->
dma_dev
=
dev
;
break
;
}
...
...
@@ -1018,15 +1021,14 @@ EXPORT_SYMBOL(ssb_dma_translation);
int
ssb_dma_set_mask
(
struct
ssb_device
*
ssb_dev
,
u64
mask
)
{
struct
device
*
d
ev
=
ssb_dev
->
dev
;
struct
device
*
d
ma_dev
=
ssb_dev
->
dma_
dev
;
#ifdef CONFIG_SSB_PCIHOST
if
(
ssb_dev
->
bus
->
bustype
==
SSB_BUSTYPE_PCI
&&
!
dma_supported
(
dev
,
mask
))
return
-
EIO
;
if
(
ssb_dev
->
bus
->
bustype
==
SSB_BUSTYPE_PCI
)
return
dma_set_mask
(
dma_dev
,
mask
);
#endif
dev
->
coherent_dma_mask
=
mask
;
d
ev
->
dma_mask
=
&
dev
->
coherent_dma_mask
;
d
ma_d
ev
->
coherent_dma_mask
=
mask
;
d
ma_dev
->
dma_mask
=
&
dma_
dev
->
coherent_dma_mask
;
return
0
;
}
...
...
include/linux/ssb/ssb.h
View file @
c4cbb34b
...
...
@@ -129,6 +129,10 @@ struct ssb_device {
const
struct
ssb_bus_ops
*
ops
;
struct
device
*
dev
;
/* Pointer to the device that has to be used for
* any DMA related operation. */
struct
device
*
dma_dev
;
struct
ssb_bus
*
bus
;
struct
ssb_device_id
id
;
...
...
net/mac80211/rx.c
View file @
c4cbb34b
...
...
@@ -1050,12 +1050,9 @@ ieee80211_drop_unencrypted(struct ieee80211_txrx_data *rx)
if
(
unlikely
(
!
(
rx
->
fc
&
IEEE80211_FCTL_PROTECTED
)
&&
(
rx
->
fc
&
IEEE80211_FCTL_FTYPE
)
==
IEEE80211_FTYPE_DATA
&&
(
rx
->
fc
&
IEEE80211_FCTL_STYPE
)
!=
IEEE80211_STYPE_NULLFUNC
&&
(
rx
->
key
||
rx
->
sdata
->
drop_unencrypted
)))
{
if
(
net_ratelimit
())
printk
(
KERN_DEBUG
"%s: RX non-WEP frame, but expected "
"encryption
\n
"
,
rx
->
dev
->
name
);
(
rx
->
key
||
rx
->
sdata
->
drop_unencrypted
)))
return
-
EACCES
;
}
return
0
;
}
...
...
net/rfkill/rfkill.c
View file @
c4cbb34b
...
...
@@ -92,7 +92,7 @@ void rfkill_switch_all(enum rfkill_type type, enum rfkill_state state)
rfkill_states
[
type
]
=
state
;
list_for_each_entry
(
rfkill
,
&
rfkill_list
,
node
)
{
if
(
!
rfkill
->
user_claim
)
if
(
(
!
rfkill
->
user_claim
)
&&
(
rfkill
->
type
==
type
)
)
rfkill_toggle_radio
(
rfkill
,
state
);
}
...
...
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