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
9df3259e
Commit
9df3259e
authored
Sep 16, 2004
by
David S. Miller
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[TYPHOON]: Fix iomem warnings.
Signed-off-by:
David S. Miller
<
davem@davemloft.net
>
parent
ece6e01b
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
26 deletions
+27
-26
drivers/net/typhoon.c
drivers/net/typhoon.c
+27
-26
No files found.
drivers/net/typhoon.c
View file @
9df3259e
...
@@ -248,11 +248,11 @@ struct typhoon {
...
@@ -248,11 +248,11 @@ struct typhoon {
/* Tx cache line section */
/* Tx cache line section */
struct
transmit_ring
txLoRing
____cacheline_aligned
;
struct
transmit_ring
txLoRing
____cacheline_aligned
;
struct
pci_dev
*
tx_pdev
;
struct
pci_dev
*
tx_pdev
;
unsigned
long
tx_ioaddr
;
void
__iomem
*
tx_ioaddr
;
u32
txlo_dma_addr
;
u32
txlo_dma_addr
;
/* Irq/Rx cache line section */
/* Irq/Rx cache line section */
unsigned
long
ioaddr
____cacheline_aligned
;
void
__iomem
*
ioaddr
____cacheline_aligned
;
struct
typhoon_indexes
*
indexes
;
struct
typhoon_indexes
*
indexes
;
u8
awaiting_resp
;
u8
awaiting_resp
;
u8
duplex
;
u8
duplex
;
...
@@ -373,7 +373,7 @@ typhoon_inc_rx_index(u32 *index, const int count)
...
@@ -373,7 +373,7 @@ typhoon_inc_rx_index(u32 *index, const int count)
}
}
static
int
static
int
typhoon_reset
(
unsigned
long
ioaddr
,
int
wait_type
)
typhoon_reset
(
void
__iomem
*
ioaddr
,
int
wait_type
)
{
{
int
i
,
err
=
0
;
int
i
,
err
=
0
;
int
timeout
;
int
timeout
;
...
@@ -428,7 +428,7 @@ typhoon_reset(unsigned long ioaddr, int wait_type)
...
@@ -428,7 +428,7 @@ typhoon_reset(unsigned long ioaddr, int wait_type)
}
}
static
int
static
int
typhoon_wait_status
(
unsigned
long
ioaddr
,
u32
wait_value
)
typhoon_wait_status
(
void
__iomem
*
ioaddr
,
u32
wait_value
)
{
{
int
i
,
err
=
0
;
int
i
,
err
=
0
;
...
@@ -1240,7 +1240,7 @@ typhoon_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
...
@@ -1240,7 +1240,7 @@ typhoon_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
}
}
static
int
static
int
typhoon_wait_interrupt
(
unsigned
long
ioaddr
)
typhoon_wait_interrupt
(
void
__iomem
*
ioaddr
)
{
{
int
i
,
err
=
0
;
int
i
,
err
=
0
;
...
@@ -1348,7 +1348,7 @@ typhoon_init_rings(struct typhoon *tp)
...
@@ -1348,7 +1348,7 @@ typhoon_init_rings(struct typhoon *tp)
static
int
static
int
typhoon_download_firmware
(
struct
typhoon
*
tp
)
typhoon_download_firmware
(
struct
typhoon
*
tp
)
{
{
unsigned
long
ioaddr
=
tp
->
ioaddr
;
void
__iomem
*
ioaddr
=
tp
->
ioaddr
;
struct
pci_dev
*
pdev
=
tp
->
pdev
;
struct
pci_dev
*
pdev
=
tp
->
pdev
;
struct
typhoon_file_header
*
fHdr
;
struct
typhoon_file_header
*
fHdr
;
struct
typhoon_section_header
*
sHdr
;
struct
typhoon_section_header
*
sHdr
;
...
@@ -1497,7 +1497,7 @@ typhoon_download_firmware(struct typhoon *tp)
...
@@ -1497,7 +1497,7 @@ typhoon_download_firmware(struct typhoon *tp)
static
int
static
int
typhoon_boot_3XP
(
struct
typhoon
*
tp
,
u32
initial_status
)
typhoon_boot_3XP
(
struct
typhoon
*
tp
,
u32
initial_status
)
{
{
unsigned
long
ioaddr
=
tp
->
ioaddr
;
void
__iomem
*
ioaddr
=
tp
->
ioaddr
;
if
(
typhoon_wait_status
(
ioaddr
,
initial_status
)
<
0
)
{
if
(
typhoon_wait_status
(
ioaddr
,
initial_status
)
<
0
)
{
printk
(
KERN_ERR
"%s: boot ready timeout
\n
"
,
tp
->
name
);
printk
(
KERN_ERR
"%s: boot ready timeout
\n
"
,
tp
->
name
);
...
@@ -1812,7 +1812,8 @@ static irqreturn_t
...
@@ -1812,7 +1812,8 @@ static irqreturn_t
typhoon_interrupt
(
int
irq
,
void
*
dev_instance
,
struct
pt_regs
*
rgs
)
typhoon_interrupt
(
int
irq
,
void
*
dev_instance
,
struct
pt_regs
*
rgs
)
{
{
struct
net_device
*
dev
=
(
struct
net_device
*
)
dev_instance
;
struct
net_device
*
dev
=
(
struct
net_device
*
)
dev_instance
;
unsigned
long
ioaddr
=
dev
->
base_addr
;
struct
typhoon
*
tp
=
dev
->
priv
;
void
__iomem
*
ioaddr
=
tp
->
ioaddr
;
u32
intr_status
;
u32
intr_status
;
intr_status
=
readl
(
ioaddr
+
TYPHOON_REG_INTR_STATUS
);
intr_status
=
readl
(
ioaddr
+
TYPHOON_REG_INTR_STATUS
);
...
@@ -1852,7 +1853,7 @@ static int
...
@@ -1852,7 +1853,7 @@ static int
typhoon_sleep
(
struct
typhoon
*
tp
,
int
state
,
u16
events
)
typhoon_sleep
(
struct
typhoon
*
tp
,
int
state
,
u16
events
)
{
{
struct
pci_dev
*
pdev
=
tp
->
pdev
;
struct
pci_dev
*
pdev
=
tp
->
pdev
;
unsigned
long
ioaddr
=
tp
->
ioaddr
;
void
__iomem
*
ioaddr
=
tp
->
ioaddr
;
struct
cmd_desc
xp_cmd
;
struct
cmd_desc
xp_cmd
;
int
err
;
int
err
;
...
@@ -1890,7 +1891,7 @@ static int
...
@@ -1890,7 +1891,7 @@ static int
typhoon_wakeup
(
struct
typhoon
*
tp
,
int
wait_type
)
typhoon_wakeup
(
struct
typhoon
*
tp
,
int
wait_type
)
{
{
struct
pci_dev
*
pdev
=
tp
->
pdev
;
struct
pci_dev
*
pdev
=
tp
->
pdev
;
unsigned
long
ioaddr
=
tp
->
ioaddr
;
void
__iomem
*
ioaddr
=
tp
->
ioaddr
;
pci_set_power_state
(
pdev
,
0
);
pci_set_power_state
(
pdev
,
0
);
pci_restore_state
(
pdev
,
tp
->
pci_state
);
pci_restore_state
(
pdev
,
tp
->
pci_state
);
...
@@ -1911,7 +1912,7 @@ static int
...
@@ -1911,7 +1912,7 @@ static int
typhoon_start_runtime
(
struct
typhoon
*
tp
)
typhoon_start_runtime
(
struct
typhoon
*
tp
)
{
{
struct
net_device
*
dev
=
tp
->
dev
;
struct
net_device
*
dev
=
tp
->
dev
;
unsigned
long
ioaddr
=
tp
->
ioaddr
;
void
__iomem
*
ioaddr
=
tp
->
ioaddr
;
struct
cmd_desc
xp_cmd
;
struct
cmd_desc
xp_cmd
;
int
err
;
int
err
;
...
@@ -2006,7 +2007,7 @@ typhoon_stop_runtime(struct typhoon *tp, int wait_type)
...
@@ -2006,7 +2007,7 @@ typhoon_stop_runtime(struct typhoon *tp, int wait_type)
{
{
struct
typhoon_indexes
*
indexes
=
tp
->
indexes
;
struct
typhoon_indexes
*
indexes
=
tp
->
indexes
;
struct
transmit_ring
*
txLo
=
&
tp
->
txLoRing
;
struct
transmit_ring
*
txLo
=
&
tp
->
txLoRing
;
unsigned
long
ioaddr
=
tp
->
ioaddr
;
void
__iomem
*
ioaddr
=
tp
->
ioaddr
;
struct
cmd_desc
xp_cmd
;
struct
cmd_desc
xp_cmd
;
int
i
;
int
i
;
...
@@ -2070,7 +2071,7 @@ typhoon_tx_timeout(struct net_device *dev)
...
@@ -2070,7 +2071,7 @@ typhoon_tx_timeout(struct net_device *dev)
{
{
struct
typhoon
*
tp
=
(
struct
typhoon
*
)
dev
->
priv
;
struct
typhoon
*
tp
=
(
struct
typhoon
*
)
dev
->
priv
;
if
(
typhoon_reset
(
dev
->
base_
addr
,
WaitNoSleep
)
<
0
)
{
if
(
typhoon_reset
(
tp
->
io
addr
,
WaitNoSleep
)
<
0
)
{
printk
(
KERN_WARNING
"%s: could not reset in tx timeout
\n
"
,
printk
(
KERN_WARNING
"%s: could not reset in tx timeout
\n
"
,
dev
->
name
);
dev
->
name
);
goto
truely_dead
;
goto
truely_dead
;
...
@@ -2091,7 +2092,7 @@ typhoon_tx_timeout(struct net_device *dev)
...
@@ -2091,7 +2092,7 @@ typhoon_tx_timeout(struct net_device *dev)
truely_dead:
truely_dead:
/* Reset the hardware, and turn off carrier to avoid more timeouts */
/* Reset the hardware, and turn off carrier to avoid more timeouts */
typhoon_reset
(
dev
->
base_
addr
,
NoWait
);
typhoon_reset
(
tp
->
io
addr
,
NoWait
);
netif_carrier_off
(
dev
);
netif_carrier_off
(
dev
);
}
}
...
@@ -2126,7 +2127,7 @@ typhoon_open(struct net_device *dev)
...
@@ -2126,7 +2127,7 @@ typhoon_open(struct net_device *dev)
if
(
typhoon_boot_3XP
(
tp
,
TYPHOON_STATUS_WAITING_FOR_HOST
)
<
0
)
{
if
(
typhoon_boot_3XP
(
tp
,
TYPHOON_STATUS_WAITING_FOR_HOST
)
<
0
)
{
printk
(
KERN_ERR
"%s: unable to reboot into sleep img
\n
"
,
printk
(
KERN_ERR
"%s: unable to reboot into sleep img
\n
"
,
dev
->
name
);
dev
->
name
);
typhoon_reset
(
dev
->
base_
addr
,
NoWait
);
typhoon_reset
(
tp
->
io
addr
,
NoWait
);
goto
out
;
goto
out
;
}
}
...
@@ -2192,7 +2193,7 @@ typhoon_resume(struct pci_dev *pdev)
...
@@ -2192,7 +2193,7 @@ typhoon_resume(struct pci_dev *pdev)
return
0
;
return
0
;
reset:
reset:
typhoon_reset
(
dev
->
base_
addr
,
NoWait
);
typhoon_reset
(
tp
->
io
addr
,
NoWait
);
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -2276,6 +2277,7 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
...
@@ -2276,6 +2277,7 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
struct
typhoon
*
tp
;
struct
typhoon
*
tp
;
int
card_id
=
(
int
)
ent
->
driver_data
;
int
card_id
=
(
int
)
ent
->
driver_data
;
unsigned
long
ioaddr
;
unsigned
long
ioaddr
;
void
__iomem
*
ioaddr_mapped
;
void
*
shared
;
void
*
shared
;
dma_addr_t
shared_dma
;
dma_addr_t
shared_dma
;
struct
cmd_desc
xp_cmd
;
struct
cmd_desc
xp_cmd
;
...
@@ -2345,14 +2347,13 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
...
@@ -2345,14 +2347,13 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
/* map our MMIO region
/* map our MMIO region
*/
*/
ioaddr
=
pci_resource_start
(
pdev
,
1
);
ioaddr
=
pci_resource_start
(
pdev
,
1
);
ioaddr
=
(
unsigned
long
)
ioremap
(
ioaddr
,
128
);
ioaddr
_mapped
=
ioremap
(
ioaddr
,
128
);
if
(
!
ioaddr
)
{
if
(
!
ioaddr_mapped
)
{
printk
(
ERR_PFX
"%s: cannot remap MMIO, aborting
\n
"
,
printk
(
ERR_PFX
"%s: cannot remap MMIO, aborting
\n
"
,
pci_name
(
pdev
));
pci_name
(
pdev
));
err
=
-
EIO
;
err
=
-
EIO
;
goto
error_out_regions
;
goto
error_out_regions
;
}
}
dev
->
base_addr
=
ioaddr
;
/* allocate pci dma space for rx and tx descriptor rings
/* allocate pci dma space for rx and tx descriptor rings
*/
*/
...
@@ -2371,8 +2372,8 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
...
@@ -2371,8 +2372,8 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
tp
->
shared_dma
=
shared_dma
;
tp
->
shared_dma
=
shared_dma
;
tp
->
pdev
=
pdev
;
tp
->
pdev
=
pdev
;
tp
->
tx_pdev
=
pdev
;
tp
->
tx_pdev
=
pdev
;
tp
->
ioaddr
=
dev
->
base_addr
;
tp
->
ioaddr
=
ioaddr_mapped
;
tp
->
tx_ioaddr
=
dev
->
base_addr
;
tp
->
tx_ioaddr
=
ioaddr_mapped
;
tp
->
dev
=
dev
;
tp
->
dev
=
dev
;
/* need to be able to restore PCI state after a suspend */
/* need to be able to restore PCI state after a suspend */
...
@@ -2385,7 +2386,7 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
...
@@ -2385,7 +2386,7 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
* 4) Get the hardware address.
* 4) Get the hardware address.
* 5) Put the card to sleep.
* 5) Put the card to sleep.
*/
*/
if
(
typhoon_reset
(
ioaddr
,
WaitSleep
)
<
0
)
{
if
(
typhoon_reset
(
ioaddr_mapped
,
WaitSleep
)
<
0
)
{
printk
(
ERR_PFX
"%s: could not reset 3XP
\n
"
,
pci_name
(
pdev
));
printk
(
ERR_PFX
"%s: could not reset 3XP
\n
"
,
pci_name
(
pdev
));
err
=
-
EIO
;
err
=
-
EIO
;
goto
error_out_dma
;
goto
error_out_dma
;
...
@@ -2518,13 +2519,13 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
...
@@ -2518,13 +2519,13 @@ typhoon_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
return
0
;
return
0
;
error_out_reset:
error_out_reset:
typhoon_reset
(
ioaddr
,
NoWait
);
typhoon_reset
(
ioaddr
_mapped
,
NoWait
);
error_out_dma:
error_out_dma:
pci_free_consistent
(
pdev
,
sizeof
(
struct
typhoon_shared
),
pci_free_consistent
(
pdev
,
sizeof
(
struct
typhoon_shared
),
shared
,
shared_dma
);
shared
,
shared_dma
);
error_out_remap:
error_out_remap:
iounmap
(
(
void
*
)
ioaddr
);
iounmap
(
ioaddr_mapped
);
error_out_regions:
error_out_regions:
pci_release_regions
(
pdev
);
pci_release_regions
(
pdev
);
error_out_dev:
error_out_dev:
...
@@ -2542,8 +2543,8 @@ typhoon_remove_one(struct pci_dev *pdev)
...
@@ -2542,8 +2543,8 @@ typhoon_remove_one(struct pci_dev *pdev)
unregister_netdev
(
dev
);
unregister_netdev
(
dev
);
pci_set_power_state
(
pdev
,
0
);
pci_set_power_state
(
pdev
,
0
);
pci_restore_state
(
pdev
,
tp
->
pci_state
);
pci_restore_state
(
pdev
,
tp
->
pci_state
);
typhoon_reset
(
dev
->
base_
addr
,
NoWait
);
typhoon_reset
(
tp
->
io
addr
,
NoWait
);
iounmap
(
(
char
*
)
(
dev
->
base_addr
)
);
iounmap
(
tp
->
ioaddr
);
pci_free_consistent
(
pdev
,
sizeof
(
struct
typhoon_shared
),
pci_free_consistent
(
pdev
,
sizeof
(
struct
typhoon_shared
),
tp
->
shared
,
tp
->
shared_dma
);
tp
->
shared
,
tp
->
shared_dma
);
pci_release_regions
(
pdev
);
pci_release_regions
(
pdev
);
...
...
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