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
1a13e9de
Commit
1a13e9de
authored
Oct 05, 2004
by
Greg Kroah-Hartman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] PCI: fix __iomem * warnings for PCI msi core code.
Signed-off-by:
Greg Kroah-Hartman
<
greg@kroah.com
>
parent
0c14584a
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
11 additions
and
11 deletions
+11
-11
drivers/pci/msi.c
drivers/pci/msi.c
+10
-10
drivers/pci/msi.h
drivers/pci/msi.h
+1
-1
No files found.
drivers/pci/msi.c
View file @
1a13e9de
...
@@ -66,7 +66,7 @@ static void msi_set_mask_bit(unsigned int vector, int flag)
...
@@ -66,7 +66,7 @@ static void msi_set_mask_bit(unsigned int vector, int flag)
int
pos
;
int
pos
;
u32
mask_bits
;
u32
mask_bits
;
pos
=
entry
->
mask_base
;
pos
=
(
int
)
entry
->
mask_base
;
pci_read_config_dword
(
entry
->
dev
,
pos
,
&
mask_bits
);
pci_read_config_dword
(
entry
->
dev
,
pos
,
&
mask_bits
);
mask_bits
&=
~
(
1
);
mask_bits
&=
~
(
1
);
mask_bits
|=
flag
;
mask_bits
|=
flag
;
...
@@ -548,7 +548,7 @@ static int msi_capability_init(struct pci_dev *dev)
...
@@ -548,7 +548,7 @@ static int msi_capability_init(struct pci_dev *dev)
dev
->
irq
=
vector
;
dev
->
irq
=
vector
;
entry
->
dev
=
dev
;
entry
->
dev
=
dev
;
if
(
is_mask_bit_support
(
control
))
{
if
(
is_mask_bit_support
(
control
))
{
entry
->
mask_base
=
msi_mask_bits_reg
(
pos
,
entry
->
mask_base
=
(
void
__iomem
*
)
msi_mask_bits_reg
(
pos
,
is_64bit_address
(
control
));
is_64bit_address
(
control
));
}
}
/* Replace with MSI handler */
/* Replace with MSI handler */
...
@@ -606,7 +606,7 @@ static int msix_capability_init(struct pci_dev *dev,
...
@@ -606,7 +606,7 @@ static int msix_capability_init(struct pci_dev *dev,
u32
phys_addr
,
table_offset
;
u32
phys_addr
,
table_offset
;
u16
control
;
u16
control
;
u8
bir
;
u8
bir
;
void
*
base
;
void
__iomem
*
base
;
pos
=
pci_find_capability
(
dev
,
PCI_CAP_ID_MSIX
);
pos
=
pci_find_capability
(
dev
,
PCI_CAP_ID_MSIX
);
/* Request & Map MSI-X table region */
/* Request & Map MSI-X table region */
...
@@ -642,7 +642,7 @@ static int msix_capability_init(struct pci_dev *dev,
...
@@ -642,7 +642,7 @@ static int msix_capability_init(struct pci_dev *dev,
entry
->
msi_attrib
.
maskbit
=
1
;
entry
->
msi_attrib
.
maskbit
=
1
;
entry
->
msi_attrib
.
default_vector
=
dev
->
irq
;
entry
->
msi_attrib
.
default_vector
=
dev
->
irq
;
entry
->
dev
=
dev
;
entry
->
dev
=
dev
;
entry
->
mask_base
=
(
unsigned
long
)
base
;
entry
->
mask_base
=
base
;
if
(
!
head
)
{
if
(
!
head
)
{
entry
->
link
.
head
=
vector
;
entry
->
link
.
head
=
vector
;
entry
->
link
.
tail
=
vector
;
entry
->
link
.
tail
=
vector
;
...
@@ -806,7 +806,7 @@ static int msi_free_vector(struct pci_dev* dev, int vector, int reassign)
...
@@ -806,7 +806,7 @@ static int msi_free_vector(struct pci_dev* dev, int vector, int reassign)
{
{
struct
msi_desc
*
entry
;
struct
msi_desc
*
entry
;
int
head
,
entry_nr
,
type
;
int
head
,
entry_nr
,
type
;
unsigned
long
base
=
0L
;
void
__iomem
*
base
;
unsigned
long
flags
;
unsigned
long
flags
;
spin_lock_irqsave
(
&
msi_lock
,
flags
);
spin_lock_irqsave
(
&
msi_lock
,
flags
);
...
@@ -857,7 +857,7 @@ static int msi_free_vector(struct pci_dev* dev, int vector, int reassign)
...
@@ -857,7 +857,7 @@ static int msi_free_vector(struct pci_dev* dev, int vector, int reassign)
phys_addr
=
pci_resource_start
(
dev
,
bir
);
phys_addr
=
pci_resource_start
(
dev
,
bir
);
phys_addr
+=
(
u32
)(
table_offset
&
phys_addr
+=
(
u32
)(
table_offset
&
~
PCI_MSIX_FLAGS_BIRMASK
);
~
PCI_MSIX_FLAGS_BIRMASK
);
iounmap
(
(
void
*
)
base
);
iounmap
(
base
);
release_mem_region
(
phys_addr
,
release_mem_region
(
phys_addr
,
nr_entries
*
PCI_MSIX_ENTRY_SIZE
);
nr_entries
*
PCI_MSIX_ENTRY_SIZE
);
}
}
...
@@ -869,8 +869,8 @@ static int msi_free_vector(struct pci_dev* dev, int vector, int reassign)
...
@@ -869,8 +869,8 @@ static int msi_free_vector(struct pci_dev* dev, int vector, int reassign)
static
int
reroute_msix_table
(
int
head
,
struct
msix_entry
*
entries
,
int
*
nvec
)
static
int
reroute_msix_table
(
int
head
,
struct
msix_entry
*
entries
,
int
*
nvec
)
{
{
int
vector
=
head
,
tail
=
0
;
int
vector
=
head
,
tail
=
0
;
int
i
=
0
,
j
=
0
,
nr_entries
=
0
;
int
i
,
j
=
0
,
nr_entries
=
0
;
unsigned
long
base
=
0L
;
void
__iomem
*
base
;
unsigned
long
flags
;
unsigned
long
flags
;
spin_lock_irqsave
(
&
msi_lock
,
flags
);
spin_lock_irqsave
(
&
msi_lock
,
flags
);
...
@@ -1099,7 +1099,7 @@ void msi_remove_pci_irq_vectors(struct pci_dev* dev)
...
@@ -1099,7 +1099,7 @@ void msi_remove_pci_irq_vectors(struct pci_dev* dev)
if
((
pos
=
pci_find_capability
(
dev
,
PCI_CAP_ID_MSIX
))
>
0
&&
if
((
pos
=
pci_find_capability
(
dev
,
PCI_CAP_ID_MSIX
))
>
0
&&
!
msi_lookup_vector
(
dev
,
PCI_CAP_ID_MSIX
))
{
!
msi_lookup_vector
(
dev
,
PCI_CAP_ID_MSIX
))
{
int
vector
,
head
,
tail
=
0
,
warning
=
0
;
int
vector
,
head
,
tail
=
0
,
warning
=
0
;
unsigned
long
base
=
0
L
;
void
__iomem
*
base
=
NUL
L
;
vector
=
head
=
dev
->
irq
;
vector
=
head
=
dev
->
irq
;
while
(
head
!=
tail
)
{
while
(
head
!=
tail
)
{
...
@@ -1129,7 +1129,7 @@ void msi_remove_pci_irq_vectors(struct pci_dev* dev)
...
@@ -1129,7 +1129,7 @@ void msi_remove_pci_irq_vectors(struct pci_dev* dev)
phys_addr
=
pci_resource_start
(
dev
,
bir
);
phys_addr
=
pci_resource_start
(
dev
,
bir
);
phys_addr
+=
(
u32
)(
table_offset
&
phys_addr
+=
(
u32
)(
table_offset
&
~
PCI_MSIX_FLAGS_BIRMASK
);
~
PCI_MSIX_FLAGS_BIRMASK
);
iounmap
(
(
void
*
)
base
);
iounmap
(
base
);
release_mem_region
(
phys_addr
,
PCI_MSIX_ENTRY_SIZE
*
release_mem_region
(
phys_addr
,
PCI_MSIX_ENTRY_SIZE
*
multi_msix_capable
(
control
));
multi_msix_capable
(
control
));
printk
(
KERN_DEBUG
"Driver[%d:%d:%d] unloaded wo doing free_irq on all vectors
\n
"
,
printk
(
KERN_DEBUG
"Driver[%d:%d:%d] unloaded wo doing free_irq on all vectors
\n
"
,
...
...
drivers/pci/msi.h
View file @
1a13e9de
...
@@ -152,7 +152,7 @@ struct msi_desc {
...
@@ -152,7 +152,7 @@ struct msi_desc {
__u16
tail
;
__u16
tail
;
}
link
;
}
link
;
unsigned
long
mask_base
;
void
__iomem
*
mask_base
;
struct
pci_dev
*
dev
;
struct
pci_dev
*
dev
;
};
};
...
...
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