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
Kirill Smelkov
linux
Commits
77882f74
Commit
77882f74
authored
May 31, 2004
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://bk.arm.linux.org.uk/linux-2.6-pcmcia
into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents
220cf2d8
62bab380
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
48 additions
and
38 deletions
+48
-38
drivers/pcmcia/pxa2xx_base.c
drivers/pcmcia/pxa2xx_base.c
+7
-9
drivers/pcmcia/sa11xx_base.c
drivers/pcmcia/sa11xx_base.c
+11
-29
drivers/pcmcia/soc_common.c
drivers/pcmcia/soc_common.c
+23
-0
drivers/pcmcia/soc_common.h
drivers/pcmcia/soc_common.h
+7
-0
No files found.
drivers/pcmcia/pxa2xx_base.c
View file @
77882f74
...
@@ -115,11 +115,14 @@ static int pxa2xx_pcmcia_set_mcatt( int sock, int speed, int clock )
...
@@ -115,11 +115,14 @@ static int pxa2xx_pcmcia_set_mcatt( int sock, int speed, int clock )
static
int
pxa2xx_pcmcia_set_mcxx
(
struct
soc_pcmcia_socket
*
skt
,
unsigned
int
lclk
)
static
int
pxa2xx_pcmcia_set_mcxx
(
struct
soc_pcmcia_socket
*
skt
,
unsigned
int
lclk
)
{
{
struct
soc_pcmcia_timing
timing
;
int
sock
=
skt
->
nr
;
int
sock
=
skt
->
nr
;
pxa2xx_pcmcia_set_mcmem
(
sock
,
SOC_PCMCIA_5V_MEM_ACCESS
,
lclk
);
soc_common_pcmcia_get_timing
(
skt
,
&
timing
);
pxa2xx_pcmcia_set_mcatt
(
sock
,
SOC_PCMCIA_ATTR_MEM_ACCESS
,
lclk
);
pxa2xx_pcmcia_set_mcio
(
sock
,
SOC_PCMCIA_IO_ACCESS
,
lclk
);
pxa2xx_pcmcia_set_mcmem
(
sock
,
timing
.
mem
,
lclk
);
pxa2xx_pcmcia_set_mcatt
(
sock
,
timing
.
attr
,
lclk
);
pxa2xx_pcmcia_set_mcio
(
sock
,
timing
.
io
,
lclk
);
return
0
;
return
0
;
}
}
...
@@ -237,12 +240,7 @@ static void pxa2xx_pcmcia_update_mcxx(unsigned int clock)
...
@@ -237,12 +240,7 @@ static void pxa2xx_pcmcia_update_mcxx(unsigned int clock)
down
(
&
soc_sockets_lock
);
down
(
&
soc_sockets_lock
);
list_for_each_entry
(
skt
,
&
soc_sockets
,
node
)
{
list_for_each_entry
(
skt
,
&
soc_sockets
,
node
)
{
pxa2xx_pcmcia_set_mcio
(
skt
->
nr
,
calc_speed
(
skt
->
spd_io
,
pxa2xx_pcmcia_set_mcxx
(
skt
,
clock
);
MAX_IO_WIN
,
SOC_PCMCIA_IO_ACCESS
),
clock
);
pxa2xx_pcmcia_set_mcmem
(
skt
->
nr
,
calc_speed
(
skt
->
spd_io
,
MAX_IO_WIN
,
SOC_PCMCIA_3V_MEM_ACCESS
),
clock
);
pxa2xx_pcmcia_set_mcatt
(
skt
->
nr
,
calc_speed
(
skt
->
spd_io
,
MAX_IO_WIN
,
SOC_PCMCIA_3V_MEM_ACCESS
),
clock
);
}
}
up
(
&
soc_sockets_lock
);
up
(
&
soc_sockets_lock
);
}
}
...
...
drivers/pcmcia/sa11xx_base.c
View file @
77882f74
...
@@ -69,21 +69,6 @@ sa1100_pcmcia_default_mecr_timing(struct soc_pcmcia_socket *skt,
...
@@ -69,21 +69,6 @@ sa1100_pcmcia_default_mecr_timing(struct soc_pcmcia_socket *skt,
return
sa1100_pcmcia_mecr_bs
(
cmd_time
,
cpu_speed
);
return
sa1100_pcmcia_mecr_bs
(
cmd_time
,
cpu_speed
);
}
}
static
unsigned
short
calc_speed
(
unsigned
short
*
spds
,
int
num
,
unsigned
short
dflt
)
{
unsigned
short
speed
=
0
;
int
i
;
for
(
i
=
0
;
i
<
num
;
i
++
)
if
(
speed
<
spds
[
i
])
speed
=
spds
[
i
];
if
(
speed
==
0
)
speed
=
dflt
;
return
speed
;
}
/* sa1100_pcmcia_set_mecr()
/* sa1100_pcmcia_set_mecr()
* ^^^^^^^^^^^^^^^^^^^^^^^^
* ^^^^^^^^^^^^^^^^^^^^^^^^
*
*
...
@@ -95,19 +80,16 @@ calc_speed(unsigned short *spds, int num, unsigned short dflt)
...
@@ -95,19 +80,16 @@ calc_speed(unsigned short *spds, int num, unsigned short dflt)
static
int
static
int
sa1100_pcmcia_set_mecr
(
struct
soc_pcmcia_socket
*
skt
,
unsigned
int
cpu_clock
)
sa1100_pcmcia_set_mecr
(
struct
soc_pcmcia_socket
*
skt
,
unsigned
int
cpu_clock
)
{
{
struct
soc_pcmcia_timing
timing
;
u32
mecr
,
old_mecr
;
u32
mecr
,
old_mecr
;
unsigned
long
flags
;
unsigned
long
flags
;
unsigned
short
speed
;
unsigned
int
bs_io
,
bs_mem
,
bs_attr
;
unsigned
int
bs_io
,
bs_mem
,
bs_attr
;
speed
=
calc_speed
(
skt
->
spd_io
,
MAX_IO_WIN
,
SOC_PCMCIA_IO_ACCESS
);
soc_common_pcmcia_get_timing
(
skt
,
&
timing
);
bs_io
=
skt
->
ops
->
get_timing
(
skt
,
cpu_clock
,
speed
);
speed
=
calc_speed
(
skt
->
spd_mem
,
MAX_WIN
,
SOC_PCMCIA_3V_MEM_ACCESS
);
bs_mem
=
skt
->
ops
->
get_timing
(
skt
,
cpu_clock
,
speed
);
speed
=
calc_speed
(
skt
->
spd_attr
,
MAX_WIN
,
SOC_PCMCIA_3V_MEM_ACCESS
);
bs_io
=
skt
->
ops
->
get_timing
(
skt
,
cpu_clock
,
timing
.
io
);
bs_attr
=
skt
->
ops
->
get_timing
(
skt
,
cpu_clock
,
speed
);
bs_mem
=
skt
->
ops
->
get_timing
(
skt
,
cpu_clock
,
timing
.
mem
);
bs_attr
=
skt
->
ops
->
get_timing
(
skt
,
cpu_clock
,
timing
.
attr
);
local_irq_save
(
flags
);
local_irq_save
(
flags
);
...
@@ -138,20 +120,20 @@ sa1100_pcmcia_set_timing(struct soc_pcmcia_socket *skt)
...
@@ -138,20 +120,20 @@ sa1100_pcmcia_set_timing(struct soc_pcmcia_socket *skt)
static
int
static
int
sa1100_pcmcia_show_timing
(
struct
soc_pcmcia_socket
*
skt
,
char
*
buf
)
sa1100_pcmcia_show_timing
(
struct
soc_pcmcia_socket
*
skt
,
char
*
buf
)
{
{
struct
soc_pcmcia_timing
timing
;
unsigned
int
clock
=
cpufreq_get
(
0
);
unsigned
int
clock
=
cpufreq_get
(
0
);
unsigned
long
mecr
=
MECR
;
unsigned
long
mecr
=
MECR
;
char
*
p
=
buf
;
char
*
p
=
buf
;
p
+=
sprintf
(
p
,
"I/O : %u (%u)
\n
"
,
soc_common_pcmcia_get_timing
(
skt
,
&
timing
);
calc_speed
(
skt
->
spd_io
,
MAX_IO_WIN
,
SOC_PCMCIA_IO_ACCESS
),
p
+=
sprintf
(
p
,
"I/O : %u (%u)
\n
"
,
timing
.
io
,
sa1100_pcmcia_cmd_time
(
clock
,
MECR_BSIO_GET
(
mecr
,
skt
->
nr
)));
sa1100_pcmcia_cmd_time
(
clock
,
MECR_BSIO_GET
(
mecr
,
skt
->
nr
)));
p
+=
sprintf
(
p
,
"attribute: %u (%u)
\n
"
,
p
+=
sprintf
(
p
,
"attribute: %u (%u)
\n
"
,
timing
.
attr
,
calc_speed
(
skt
->
spd_attr
,
MAX_WIN
,
SOC_PCMCIA_3V_MEM_ACCESS
),
sa1100_pcmcia_cmd_time
(
clock
,
MECR_BSA_GET
(
mecr
,
skt
->
nr
)));
sa1100_pcmcia_cmd_time
(
clock
,
MECR_BSA_GET
(
mecr
,
skt
->
nr
)));
p
+=
sprintf
(
p
,
"common : %u (%u)
\n
"
,
p
+=
sprintf
(
p
,
"common : %u (%u)
\n
"
,
timing
.
mem
,
calc_speed
(
skt
->
spd_mem
,
MAX_WIN
,
SOC_PCMCIA_3V_MEM_ACCESS
),
sa1100_pcmcia_cmd_time
(
clock
,
MECR_BSM_GET
(
mecr
,
skt
->
nr
)));
sa1100_pcmcia_cmd_time
(
clock
,
MECR_BSM_GET
(
mecr
,
skt
->
nr
)));
return
p
-
buf
;
return
p
-
buf
;
...
...
drivers/pcmcia/soc_common.c
View file @
77882f74
...
@@ -68,6 +68,29 @@ void soc_pcmcia_debug(struct soc_pcmcia_socket *skt, const char *func,
...
@@ -68,6 +68,29 @@ void soc_pcmcia_debug(struct soc_pcmcia_socket *skt, const char *func,
#define to_soc_pcmcia_socket(x) container_of(x, struct soc_pcmcia_socket, socket)
#define to_soc_pcmcia_socket(x) container_of(x, struct soc_pcmcia_socket, socket)
static
unsigned
short
calc_speed
(
unsigned
short
*
spds
,
int
num
,
unsigned
short
dflt
)
{
unsigned
short
speed
=
0
;
int
i
;
for
(
i
=
0
;
i
<
num
;
i
++
)
if
(
speed
<
spds
[
i
])
speed
=
spds
[
i
];
if
(
speed
==
0
)
speed
=
dflt
;
return
speed
;
}
void
soc_common_pcmcia_get_timing
(
struct
soc_pcmcia_socket
*
skt
,
struct
soc_pcmcia_timing
*
timing
)
{
timing
->
io
=
calc_speed
(
skt
->
spd_io
,
MAX_IO_WIN
,
SOC_PCMCIA_IO_ACCESS
);
timing
->
mem
=
calc_speed
(
skt
->
spd_mem
,
MAX_WIN
,
SOC_PCMCIA_3V_MEM_ACCESS
);
timing
->
attr
=
calc_speed
(
skt
->
spd_attr
,
MAX_WIN
,
SOC_PCMCIA_3V_MEM_ACCESS
);
}
EXPORT_SYMBOL
(
soc_common_pcmcia_get_timing
);
static
unsigned
int
soc_common_pcmcia_skt_state
(
struct
soc_pcmcia_socket
*
skt
)
static
unsigned
int
soc_common_pcmcia_skt_state
(
struct
soc_pcmcia_socket
*
skt
)
{
{
struct
pcmcia_state
state
;
struct
pcmcia_state
state
;
...
...
drivers/pcmcia/soc_common.h
View file @
77882f74
...
@@ -112,10 +112,17 @@ struct pcmcia_irqs {
...
@@ -112,10 +112,17 @@ struct pcmcia_irqs {
const
char
*
str
;
const
char
*
str
;
};
};
struct
soc_pcmcia_timing
{
unsigned
short
io
;
unsigned
short
mem
;
unsigned
short
attr
;
};
extern
int
soc_pcmcia_request_irqs
(
struct
soc_pcmcia_socket
*
skt
,
struct
pcmcia_irqs
*
irqs
,
int
nr
);
extern
int
soc_pcmcia_request_irqs
(
struct
soc_pcmcia_socket
*
skt
,
struct
pcmcia_irqs
*
irqs
,
int
nr
);
extern
void
soc_pcmcia_free_irqs
(
struct
soc_pcmcia_socket
*
skt
,
struct
pcmcia_irqs
*
irqs
,
int
nr
);
extern
void
soc_pcmcia_free_irqs
(
struct
soc_pcmcia_socket
*
skt
,
struct
pcmcia_irqs
*
irqs
,
int
nr
);
extern
void
soc_pcmcia_disable_irqs
(
struct
soc_pcmcia_socket
*
skt
,
struct
pcmcia_irqs
*
irqs
,
int
nr
);
extern
void
soc_pcmcia_disable_irqs
(
struct
soc_pcmcia_socket
*
skt
,
struct
pcmcia_irqs
*
irqs
,
int
nr
);
extern
void
soc_pcmcia_enable_irqs
(
struct
soc_pcmcia_socket
*
skt
,
struct
pcmcia_irqs
*
irqs
,
int
nr
);
extern
void
soc_pcmcia_enable_irqs
(
struct
soc_pcmcia_socket
*
skt
,
struct
pcmcia_irqs
*
irqs
,
int
nr
);
extern
void
soc_common_pcmcia_get_timing
(
struct
soc_pcmcia_socket
*
,
struct
soc_pcmcia_timing
*
);
extern
struct
list_head
soc_pcmcia_sockets
;
extern
struct
list_head
soc_pcmcia_sockets
;
...
...
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