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
60fab81b
Commit
60fab81b
authored
Sep 30, 2003
by
Stephen Hemminger
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[IRDA]: In smsc-ircc2 use request_region earlier in the setup process.
parent
1892661a
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
37 additions
and
39 deletions
+37
-39
drivers/net/irda/smsc-ircc2.c
drivers/net/irda/smsc-ircc2.c
+37
-39
No files found.
drivers/net/irda/smsc-ircc2.c
View file @
60fab81b
...
@@ -140,7 +140,7 @@ static const char *driver_name = "smsc-ircc2";
...
@@ -140,7 +140,7 @@ static const char *driver_name = "smsc-ircc2";
static
int
smsc_ircc_open
(
unsigned
int
firbase
,
unsigned
int
sirbase
,
u8
dma
,
u8
irq
);
static
int
smsc_ircc_open
(
unsigned
int
firbase
,
unsigned
int
sirbase
,
u8
dma
,
u8
irq
);
static
int
smsc_ircc_present
(
unsigned
int
fir_base
,
unsigned
int
sir_base
);
static
int
smsc_ircc_present
(
unsigned
int
fir_base
,
unsigned
int
sir_base
);
static
int
smsc_ircc_setup_io
(
struct
smsc_ircc_cb
*
self
,
unsigned
int
fir_base
,
unsigned
int
sir_base
,
u8
dma
,
u8
irq
);
static
void
smsc_ircc_setup_io
(
struct
smsc_ircc_cb
*
self
,
unsigned
int
fir_base
,
unsigned
int
sir_base
,
u8
dma
,
u8
irq
);
static
int
smsc_ircc_setup_buffers
(
struct
smsc_ircc_cb
*
self
);
static
int
smsc_ircc_setup_buffers
(
struct
smsc_ircc_cb
*
self
);
static
void
smsc_ircc_setup_qos
(
struct
smsc_ircc_cb
*
self
);
static
void
smsc_ircc_setup_qos
(
struct
smsc_ircc_cb
*
self
);
static
int
smsc_ircc_setup_netdev
(
struct
smsc_ircc_cb
*
self
);
static
int
smsc_ircc_setup_netdev
(
struct
smsc_ircc_cb
*
self
);
...
@@ -370,12 +370,14 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
...
@@ -370,12 +370,14 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
IRDA_DEBUG
(
1
,
"%s
\n
"
,
__FUNCTION__
);
IRDA_DEBUG
(
1
,
"%s
\n
"
,
__FUNCTION__
);
err
=
smsc_ircc_present
(
fir_base
,
sir_base
);
err
=
smsc_ircc_present
(
fir_base
,
sir_base
);
if
(
err
)
return
-
ENODEV
;
if
(
err
)
goto
err_out
;
err
=
-
ENOMEM
;
if
(
dev_count
>
DIM
(
dev_self
))
{
if
(
dev_count
>
DIM
(
dev_self
))
{
WARNING
(
"%s(), too many devices!
\n
"
,
__FUNCTION__
);
WARNING
(
"%s(), too many devices!
\n
"
,
__FUNCTION__
);
return
-
ENOMEM
;
goto
err_out1
;
}
}
/*
/*
...
@@ -385,7 +387,7 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
...
@@ -385,7 +387,7 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
if
(
self
==
NULL
)
{
if
(
self
==
NULL
)
{
ERROR
(
"%s, Can't allocate memory for control block!
\n
"
,
ERROR
(
"%s, Can't allocate memory for control block!
\n
"
,
driver_name
);
driver_name
);
return
-
ENOMEM
;
goto
err_out1
;
}
}
memset
(
self
,
0
,
sizeof
(
struct
smsc_ircc_cb
));
memset
(
self
,
0
,
sizeof
(
struct
smsc_ircc_cb
));
...
@@ -394,10 +396,10 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
...
@@ -394,10 +396,10 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
spin_lock_init
(
&
self
->
lock
);
spin_lock_init
(
&
self
->
lock
);
err
=
smsc_ircc_setup_buffers
(
self
);
err
=
smsc_ircc_setup_buffers
(
self
);
if
(
err
)
return
err
;
if
(
err
)
goto
err_out1
;
err
=
smsc_ircc_setup_io
(
self
,
fir_base
,
sir_base
,
dma
,
irq
);
smsc_ircc_setup_io
(
self
,
fir_base
,
sir_base
,
dma
,
irq
);
if
(
err
)
return
err
;
smsc_ircc_setup_qos
(
self
);
smsc_ircc_setup_qos
(
self
);
...
@@ -409,13 +411,20 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
...
@@ -409,13 +411,20 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
else
smsc_ircc_probe_transceiver
(
self
);
else
smsc_ircc_probe_transceiver
(
self
);
err
=
smsc_ircc_setup_netdev
(
self
);
err
=
smsc_ircc_setup_netdev
(
self
);
if
(
err
)
return
err
;
if
(
err
)
goto
err_out1
;
self
->
pmdev
=
pm_register
(
PM_SYS_DEV
,
PM_SYS_IRDA
,
smsc_ircc_pmproc
);
self
->
pmdev
=
pm_register
(
PM_SYS_DEV
,
PM_SYS_IRDA
,
smsc_ircc_pmproc
);
if
(
self
->
pmdev
)
if
(
self
->
pmdev
)
self
->
pmdev
->
data
=
self
;
self
->
pmdev
->
data
=
self
;
return
0
;
return
0
;
err_out1:
release_region
(
fir_base
,
SMSC_IRCC2_FIR_CHIP_IO_EXTENT
);
release_region
(
sir_base
,
SMSC_IRCC2_SIR_CHIP_IO_EXTENT
);
err_out:
return
err
;
}
}
/*
/*
...
@@ -428,18 +437,20 @@ static int smsc_ircc_present(unsigned int fir_base, unsigned int sir_base)
...
@@ -428,18 +437,20 @@ static int smsc_ircc_present(unsigned int fir_base, unsigned int sir_base)
{
{
unsigned
char
low
,
high
,
chip
,
config
,
dma
,
irq
,
version
;
unsigned
char
low
,
high
,
chip
,
config
,
dma
,
irq
,
version
;
if
(
check_region
(
fir_base
,
SMSC_IRCC2_FIR_CHIP_IO_EXTENT
)
<
0
)
{
if
(
!
request_region
(
fir_base
,
SMSC_IRCC2_FIR_CHIP_IO_EXTENT
,
driver_name
))
{
WARNING
(
"%s: can't get fir_base of 0x%03x
\n
"
,
WARNING
(
"%s: can't get fir_base of 0x%03x
\n
"
,
__FUNCTION__
,
fir_base
);
__FUNCTION__
,
fir_base
);
return
-
ENODEV
;
goto
out1
;
}
}
#if POSSIBLE_USED_BY_SERIAL_DRIVER
if
(
check_region
(
sir_base
,
SMSC_IRCC2_SIR_CHIP_IO_EXTENT
)
<
0
)
{
if
(
!
request_region
(
sir_base
,
SMSC_IRCC2_SIR_CHIP_IO_EXTENT
,
driver_name
))
{
WARNING
(
"%s: can't get sir_base of 0x%03x
\n
"
,
WARNING
(
"%s: can't get sir_base of 0x%03x
\n
"
,
__FUNCTION__
,
sir_base
);
__FUNCTION__
,
sir_base
);
return
-
ENODEV
;
goto
out2
;
}
}
#endif
register_bank
(
fir_base
,
3
);
register_bank
(
fir_base
,
3
);
...
@@ -454,13 +465,20 @@ static int smsc_ircc_present(unsigned int fir_base, unsigned int sir_base)
...
@@ -454,13 +465,20 @@ static int smsc_ircc_present(unsigned int fir_base, unsigned int sir_base)
if
(
high
!=
0x10
||
low
!=
0xb8
||
(
chip
!=
0xf1
&&
chip
!=
0xf2
))
{
if
(
high
!=
0x10
||
low
!=
0xb8
||
(
chip
!=
0xf1
&&
chip
!=
0xf2
))
{
WARNING
(
"%s(), addr 0x%04x - no device found!
\n
"
,
WARNING
(
"%s(), addr 0x%04x - no device found!
\n
"
,
__FUNCTION__
,
fir_base
);
__FUNCTION__
,
fir_base
);
return
-
ENODEV
;
goto
out3
;
}
}
MESSAGE
(
"SMsC IrDA Controller found
\n
IrCC version %d.%d, "
MESSAGE
(
"SMsC IrDA Controller found
\n
IrCC version %d.%d, "
"firport 0x%03x, sirport 0x%03x dma=%d, irq=%d
\n
"
,
"firport 0x%03x, sirport 0x%03x dma=%d, irq=%d
\n
"
,
chip
&
0x0f
,
version
,
fir_base
,
sir_base
,
dma
,
irq
);
chip
&
0x0f
,
version
,
fir_base
,
sir_base
,
dma
,
irq
);
return
0
;
return
0
;
out3:
release_region
(
fir_base
,
SMSC_IRCC2_FIR_CHIP_IO_EXTENT
);
out2:
release_region
(
fir_base
,
SMSC_IRCC2_FIR_CHIP_IO_EXTENT
);
out1:
return
-
ENODEV
;
}
}
/*
/*
...
@@ -510,10 +528,11 @@ static int smsc_ircc_setup_buffers(struct smsc_ircc_cb *self)
...
@@ -510,10 +528,11 @@ static int smsc_ircc_setup_buffers(struct smsc_ircc_cb *self)
* Setup I/O
* Setup I/O
*
*
*/
*/
static
int
smsc_ircc_setup_io
(
struct
smsc_ircc_cb
*
self
,
unsigned
int
fir_base
,
unsigned
int
sir_base
,
u8
dma
,
u8
irq
)
static
void
smsc_ircc_setup_io
(
struct
smsc_ircc_cb
*
self
,
unsigned
int
fir_base
,
unsigned
int
sir_base
,
u8
dma
,
u8
irq
)
{
{
unsigned
char
config
,
chip_dma
,
chip_irq
;
unsigned
char
config
,
chip_dma
,
chip_irq
;
void
*
ret
;
register_bank
(
fir_base
,
3
);
register_bank
(
fir_base
,
3
);
config
=
inb
(
fir_base
+
IRCC_INTERFACE
);
config
=
inb
(
fir_base
+
IRCC_INTERFACE
);
...
@@ -545,27 +564,6 @@ static int smsc_ircc_setup_io(struct smsc_ircc_cb *self, unsigned int fir_base,
...
@@ -545,27 +564,6 @@ static int smsc_ircc_setup_io(struct smsc_ircc_cb *self, unsigned int fir_base,
else
else
self
->
io
.
dma
=
chip_dma
;
self
->
io
.
dma
=
chip_dma
;
ret
=
request_region
(
self
->
io
.
fir_base
,
self
->
io
.
fir_ext
,
driver_name
);
if
(
!
ret
)
{
WARNING
(
"%s(), can't get iobase of 0x%03x
\n
"
,
__FUNCTION__
,
self
->
io
.
fir_base
);
kfree
(
self
->
tx_buff
.
head
);
kfree
(
self
->
rx_buff
.
head
);
kfree
(
self
);
return
-
ENODEV
;
}
ret
=
request_region
(
self
->
io
.
sir_base
,
self
->
io
.
sir_ext
,
driver_name
);
if
(
!
ret
)
{
WARNING
(
"%s(), can't get iobase of 0x%03x
\n
"
,
__FUNCTION__
,
self
->
io
.
sir_base
);
release_region
(
self
->
io
.
fir_base
,
self
->
io
.
fir_ext
);
kfree
(
self
->
tx_buff
.
head
);
kfree
(
self
->
rx_buff
.
head
);
kfree
(
self
);
return
-
ENODEV
;
}
return
0
;
}
}
/*
/*
...
...
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