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
144c7494
Commit
144c7494
authored
Aug 20, 2010
by
Paul Mundt
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'sh/pci-express-integration'
parents
d2d5bc58
65c23f54
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
36 additions
and
21 deletions
+36
-21
arch/sh/drivers/pci/ops-sh7786.c
arch/sh/drivers/pci/ops-sh7786.c
+18
-9
arch/sh/drivers/pci/pcie-sh7786.c
arch/sh/drivers/pci/pcie-sh7786.c
+18
-12
No files found.
arch/sh/drivers/pci/ops-sh7786.c
View file @
144c7494
/*
/*
* Generic SH7786 PCI-Express operations.
* Generic SH7786 PCI-Express operations.
*
*
* Copyright (C) 2009 Paul Mundt
* Copyright (C) 2009
- 2010
Paul Mundt
*
*
* This file is subject to the terms and conditions of the GNU General Public
* This file is subject to the terms and conditions of the GNU General Public
* License v2. See the file "COPYING" in the main directory of this archive
* License v2. See the file "COPYING" in the main directory of this archive
...
@@ -25,32 +25,39 @@ static int sh7786_pcie_config_access(unsigned char access_type,
...
@@ -25,32 +25,39 @@ static int sh7786_pcie_config_access(unsigned char access_type,
struct
pci_bus
*
bus
,
unsigned
int
devfn
,
int
where
,
u32
*
data
)
struct
pci_bus
*
bus
,
unsigned
int
devfn
,
int
where
,
u32
*
data
)
{
{
struct
pci_channel
*
chan
=
bus
->
sysdata
;
struct
pci_channel
*
chan
=
bus
->
sysdata
;
int
dev
,
func
;
int
dev
,
func
,
type
;
dev
=
PCI_SLOT
(
devfn
);
dev
=
PCI_SLOT
(
devfn
);
func
=
PCI_FUNC
(
devfn
);
func
=
PCI_FUNC
(
devfn
);
type
=
!!
bus
->
parent
;
if
(
bus
->
number
>
255
||
dev
>
31
||
func
>
7
)
if
(
bus
->
number
>
255
||
dev
>
31
||
func
>
7
)
return
PCIBIOS_FUNC_NOT_SUPPORTED
;
return
PCIBIOS_FUNC_NOT_SUPPORTED
;
if
(
devfn
)
if
(
bus
->
parent
==
NULL
&&
dev
)
return
PCIBIOS_DEVICE_NOT_FOUND
;
return
PCIBIOS_DEVICE_NOT_FOUND
;
/* Clear errors */
pci_write_reg
(
chan
,
pci_read_reg
(
chan
,
SH4A_PCIEERRFR
),
SH4A_PCIEERRFR
);
/* Set the PIO address */
/* Set the PIO address */
pci_write_reg
(
chan
,
(
bus
->
number
<<
24
)
|
(
dev
<<
19
)
|
pci_write_reg
(
chan
,
(
bus
->
number
<<
24
)
|
(
dev
<<
19
)
|
(
func
<<
16
)
|
(
where
&
~
3
),
SH4A_PCIEPAR
);
(
func
<<
16
)
|
(
where
&
~
3
),
SH4A_PCIEPAR
);
/* Enable the configuration access */
/* Enable the configuration access */
pci_write_reg
(
chan
,
(
1
<<
31
),
SH4A_PCIEPCTLR
);
pci_write_reg
(
chan
,
(
1
<<
31
)
|
(
type
<<
8
),
SH4A_PCIEPCTLR
);
/* Check for errors */
if
(
pci_read_reg
(
chan
,
SH4A_PCIEERRFR
)
&
0x10
)
return
PCIBIOS_DEVICE_NOT_FOUND
;
/* Check for master and target aborts */
if
(
pci_read_reg
(
chan
,
SH4A_PCIEPCICONF1
)
&
((
1
<<
29
)
|
(
1
<<
28
)))
return
PCIBIOS_DEVICE_NOT_FOUND
;
if
(
access_type
==
PCI_ACCESS_READ
)
if
(
access_type
==
PCI_ACCESS_READ
)
*
data
=
pci_read_reg
(
chan
,
SH4A_PCIEPDR
);
*
data
=
pci_read_reg
(
chan
,
SH4A_PCIEPDR
);
else
else
pci_write_reg
(
chan
,
*
data
,
SH4A_PCIEPDR
);
pci_write_reg
(
chan
,
*
data
,
SH4A_PCIEPDR
);
/* Check for master and target aborts */
if
(
pci_read_reg
(
chan
,
SH4A_PCIEPCICONF1
)
&
((
1
<<
29
)
|
(
1
<<
28
)))
return
PCIBIOS_DEVICE_NOT_FOUND
;
return
PCIBIOS_SUCCESSFUL
;
return
PCIBIOS_SUCCESSFUL
;
}
}
...
@@ -69,8 +76,10 @@ static int sh7786_pcie_read(struct pci_bus *bus, unsigned int devfn,
...
@@ -69,8 +76,10 @@ static int sh7786_pcie_read(struct pci_bus *bus, unsigned int devfn,
spin_lock_irqsave
(
&
sh7786_pcie_lock
,
flags
);
spin_lock_irqsave
(
&
sh7786_pcie_lock
,
flags
);
ret
=
sh7786_pcie_config_access
(
PCI_ACCESS_READ
,
bus
,
ret
=
sh7786_pcie_config_access
(
PCI_ACCESS_READ
,
bus
,
devfn
,
where
,
&
data
);
devfn
,
where
,
&
data
);
if
(
ret
!=
PCIBIOS_SUCCESSFUL
)
if
(
ret
!=
PCIBIOS_SUCCESSFUL
)
{
*
val
=
0xffffffff
;
goto
out
;
goto
out
;
}
if
(
size
==
1
)
if
(
size
==
1
)
*
val
=
(
data
>>
((
where
&
3
)
<<
3
))
&
0xff
;
*
val
=
(
data
>>
((
where
&
3
)
<<
3
))
&
0xff
;
...
...
arch/sh/drivers/pci/pcie-sh7786.c
View file @
144c7494
...
@@ -148,16 +148,11 @@ static int pci_wait_for_irq(struct pci_channel *chan, unsigned int mask)
...
@@ -148,16 +148,11 @@ static int pci_wait_for_irq(struct pci_channel *chan, unsigned int mask)
static
void
phy_write_reg
(
struct
pci_channel
*
chan
,
unsigned
int
addr
,
static
void
phy_write_reg
(
struct
pci_channel
*
chan
,
unsigned
int
addr
,
unsigned
int
lane
,
unsigned
int
data
)
unsigned
int
lane
,
unsigned
int
data
)
{
{
unsigned
long
phyaddr
,
ctrl
;
unsigned
long
phyaddr
;
phyaddr
=
(
1
<<
BITS_CMD
)
+
((
lane
&
0xf
)
<<
BITS_LANE
)
+
phyaddr
=
(
1
<<
BITS_CMD
)
+
((
lane
&
0xf
)
<<
BITS_LANE
)
+
((
addr
&
0xff
)
<<
BITS_ADR
);
((
addr
&
0xff
)
<<
BITS_ADR
);
/* Enable clock */
ctrl
=
pci_read_reg
(
chan
,
SH4A_PCIEPHYCTLR
);
ctrl
|=
(
1
<<
BITS_CKE
);
pci_write_reg
(
chan
,
ctrl
,
SH4A_PCIEPHYCTLR
);
/* Set write data */
/* Set write data */
pci_write_reg
(
chan
,
data
,
SH4A_PCIEPHYDOUTR
);
pci_write_reg
(
chan
,
data
,
SH4A_PCIEPHYDOUTR
);
pci_write_reg
(
chan
,
phyaddr
,
SH4A_PCIEPHYADRR
);
pci_write_reg
(
chan
,
phyaddr
,
SH4A_PCIEPHYADRR
);
...
@@ -165,20 +160,22 @@ static void phy_write_reg(struct pci_channel *chan, unsigned int addr,
...
@@ -165,20 +160,22 @@ static void phy_write_reg(struct pci_channel *chan, unsigned int addr,
phy_wait_for_ack
(
chan
);
phy_wait_for_ack
(
chan
);
/* Clear command */
/* Clear command */
pci_write_reg
(
chan
,
0
,
SH4A_PCIEPHYDOUTR
);
pci_write_reg
(
chan
,
0
,
SH4A_PCIEPHYADRR
);
pci_write_reg
(
chan
,
0
,
SH4A_PCIEPHYADRR
);
phy_wait_for_ack
(
chan
);
phy_wait_for_ack
(
chan
);
/* Disable clock */
ctrl
=
pci_read_reg
(
chan
,
SH4A_PCIEPHYCTLR
);
ctrl
&=
~
(
1
<<
BITS_CKE
);
pci_write_reg
(
chan
,
ctrl
,
SH4A_PCIEPHYCTLR
);
}
}
static
int
phy_init
(
struct
pci_channel
*
chan
)
static
int
phy_init
(
struct
pci_channel
*
chan
)
{
{
unsigned
long
ctrl
;
unsigned
int
timeout
=
100
;
unsigned
int
timeout
=
100
;
/* Enable clock */
ctrl
=
pci_read_reg
(
chan
,
SH4A_PCIEPHYCTLR
);
ctrl
|=
(
1
<<
BITS_CKE
);
pci_write_reg
(
chan
,
ctrl
,
SH4A_PCIEPHYCTLR
);
/* Initialize the phy */
/* Initialize the phy */
phy_write_reg
(
chan
,
0x60
,
0xf
,
0x004b008b
);
phy_write_reg
(
chan
,
0x60
,
0xf
,
0x004b008b
);
phy_write_reg
(
chan
,
0x61
,
0xf
,
0x00007b41
);
phy_write_reg
(
chan
,
0x61
,
0xf
,
0x00007b41
);
...
@@ -187,9 +184,15 @@ static int phy_init(struct pci_channel *chan)
...
@@ -187,9 +184,15 @@ static int phy_init(struct pci_channel *chan)
phy_write_reg
(
chan
,
0x66
,
0xf
,
0x00000010
);
phy_write_reg
(
chan
,
0x66
,
0xf
,
0x00000010
);
phy_write_reg
(
chan
,
0x74
,
0xf
,
0x0007001c
);
phy_write_reg
(
chan
,
0x74
,
0xf
,
0x0007001c
);
phy_write_reg
(
chan
,
0x79
,
0xf
,
0x01fc000d
);
phy_write_reg
(
chan
,
0x79
,
0xf
,
0x01fc000d
);
phy_write_reg
(
chan
,
0xb0
,
0xf
,
0x00000610
);
/* Deassert Standby */
/* Deassert Standby */
phy_write_reg
(
chan
,
0x67
,
0xf
,
0x00000400
);
phy_write_reg
(
chan
,
0x67
,
0x1
,
0x00000400
);
/* Disable clock */
ctrl
=
pci_read_reg
(
chan
,
SH4A_PCIEPHYCTLR
);
ctrl
&=
~
(
1
<<
BITS_CKE
);
pci_write_reg
(
chan
,
ctrl
,
SH4A_PCIEPHYCTLR
);
while
(
timeout
--
)
{
while
(
timeout
--
)
{
if
(
pci_read_reg
(
chan
,
SH4A_PCIEPHYSR
))
if
(
pci_read_reg
(
chan
,
SH4A_PCIEPHYSR
))
...
@@ -287,6 +290,9 @@ static int pcie_init(struct sh7786_pcie_port *port)
...
@@ -287,6 +290,9 @@ static int pcie_init(struct sh7786_pcie_port *port)
__raw_writel
(
memphys
,
chan
->
reg_base
+
SH4A_PCIELAR0
);
__raw_writel
(
memphys
,
chan
->
reg_base
+
SH4A_PCIELAR0
);
__raw_writel
((
memsize
-
SZ_256
)
|
1
,
chan
->
reg_base
+
SH4A_PCIELAMR0
);
__raw_writel
((
memsize
-
SZ_256
)
|
1
,
chan
->
reg_base
+
SH4A_PCIELAMR0
);
__raw_writel
(
memphys
,
chan
->
reg_base
+
SH4A_PCIEPCICONF4
);
__raw_writel
(
0
,
chan
->
reg_base
+
SH4A_PCIEPCICONF5
);
/* Finish initialization */
/* Finish initialization */
data
=
pci_read_reg
(
chan
,
SH4A_PCIETCTLR
);
data
=
pci_read_reg
(
chan
,
SH4A_PCIETCTLR
);
data
|=
0x1
;
data
|=
0x1
;
...
...
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