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
af0cf44c
Commit
af0cf44c
authored
Sep 21, 2003
by
Adam Belay
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PNPBIOS] move detection code into core.c
This patch moves the detection code to a more appropriate file.
parent
3b4216cf
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
92 additions
and
90 deletions
+92
-90
drivers/pnp/pnpbios/bioscalls.c
drivers/pnp/pnpbios/bioscalls.c
+3
-86
drivers/pnp/pnpbios/core.c
drivers/pnp/pnpbios/core.c
+63
-2
drivers/pnp/pnpbios/pnpbios.h
drivers/pnp/pnpbios/pnpbios.h
+26
-2
No files found.
drivers/pnp/pnpbios/bioscalls.c
View file @
af0cf44c
...
...
@@ -23,41 +23,7 @@
#include <asm/system.h>
#include <asm/byteorder.h>
/* PnP BIOS signature: "$PnP" */
#define PNP_SIGNATURE (('$' << 0) + ('P' << 8) + ('n' << 16) + ('P' << 24))
#pragma pack(1)
union
pnp_bios_expansion_header
{
struct
{
u32
signature
;
/* "$PnP" */
u8
version
;
/* in BCD */
u8
length
;
/* length in bytes, currently 21h */
u16
control
;
/* system capabilities */
u8
checksum
;
/* all bytes must add up to 0 */
u32
eventflag
;
/* phys. address of the event flag */
u16
rmoffset
;
/* real mode entry point */
u16
rmcseg
;
u16
pm16offset
;
/* 16 bit protected mode entry */
u32
pm16cseg
;
u32
deviceID
;
/* EISA encoded system ID or 0 */
u16
rmdseg
;
/* real mode data segment */
u32
pm16dseg
;
/* 16 bit pm data segment base */
}
fields
;
char
chars
[
0x21
];
/* To calculate the checksum */
};
#pragma pack()
static
union
pnp_bios_expansion_header
*
pnp_bios_hdr
=
NULL
;
/*
* Call this only after init time
*/
static
int
pnp_bios_present
(
void
)
{
return
(
pnp_bios_hdr
!=
NULL
);
}
#include "pnpbios.h"
static
struct
{
u16
offset
;
...
...
@@ -557,10 +523,10 @@ static int pnp_bios_write_escd(char *data, u32 nvram_base)
/*
*
Probing and
Initialization
* Initialization
*/
static
void
pnpbios_prepare_bios_calls
(
union
pnp_bios_expansion_header
*
header
)
void
pnpbios_calls_init
(
union
pnp_bios_install_struct
*
header
)
{
int
i
;
spin_lock_init
(
&
pnp_bios_lock
);
...
...
@@ -576,52 +542,3 @@ static void pnpbios_prepare_bios_calls(union pnp_bios_expansion_header *header)
Q_SET_SEL
(
i
,
PNP_DS
,
header
->
fields
.
pm16dseg
,
64
*
1024
);
}
}
int
pnpbios_probe_installation
(
void
)
{
union
pnp_bios_expansion_header
*
check
;
u8
sum
;
int
length
,
i
;
printk
(
KERN_INFO
"PnPBIOS: Scanning system for PnP BIOS support...
\n
"
);
/*
* Search the defined area (0xf0000-0xffff0) for a valid PnP BIOS
* structure and, if one is found, sets up the selectors and
* entry points
*/
for
(
check
=
(
union
pnp_bios_expansion_header
*
)
__va
(
0xf0000
);
check
<
(
union
pnp_bios_expansion_header
*
)
__va
(
0xffff0
);
((
void
*
)
(
check
))
+=
16
)
{
if
(
check
->
fields
.
signature
!=
PNP_SIGNATURE
)
continue
;
printk
(
KERN_INFO
"PnPBIOS: Found PnP BIOS installation structure at 0x%p
\n
"
,
check
);
length
=
check
->
fields
.
length
;
if
(
!
length
)
{
printk
(
KERN_ERR
"PnPBIOS: installation structure is invalid, skipping
\n
"
);
continue
;
}
for
(
sum
=
0
,
i
=
0
;
i
<
length
;
i
++
)
sum
+=
check
->
chars
[
i
];
if
(
sum
)
{
printk
(
KERN_ERR
"PnPBIOS: installation structure is corrupted, skipping
\n
"
);
continue
;
}
if
(
check
->
fields
.
version
<
0x10
)
{
printk
(
KERN_WARNING
"PnPBIOS: PnP BIOS version %d.%d is not supported
\n
"
,
check
->
fields
.
version
>>
4
,
check
->
fields
.
version
&
15
);
continue
;
}
printk
(
KERN_INFO
"PnPBIOS: PnP BIOS version %d.%d, entry 0x%x:0x%x, dseg 0x%x
\n
"
,
check
->
fields
.
version
>>
4
,
check
->
fields
.
version
&
15
,
check
->
fields
.
pm16cseg
,
check
->
fields
.
pm16offset
,
check
->
fields
.
pm16dseg
);
pnp_bios_hdr
=
check
;
pnpbios_prepare_bios_calls
(
check
);
return
1
;
}
printk
(
KERN_INFO
"PnPBIOS: PnP BIOS support was not detected.
\n
"
);
return
0
;
}
drivers/pnp/pnpbios/core.c
View file @
af0cf44c
...
...
@@ -74,6 +74,13 @@
*
*/
static
union
pnp_bios_install_struct
*
pnp_bios_install
=
NULL
;
int
pnp_bios_present
(
void
)
{
return
(
pnp_bios_install
!=
NULL
);
}
struct
pnp_dev_node_info
node_info
;
void
*
pnpbios_kmalloc
(
size_t
size
,
int
f
)
...
...
@@ -410,7 +417,56 @@ static int __init pnpbios_setup(char *str)
__setup
(
"pnpbios="
,
pnpbios_setup
);
#endif
subsys_initcall
(
pnpbios_init
);
/* PnP BIOS signature: "$PnP" */
#define PNP_SIGNATURE (('$' << 0) + ('P' << 8) + ('n' << 16) + ('P' << 24))
int
__init
pnpbios_probe_system
(
void
)
{
union
pnp_bios_install_struct
*
check
;
u8
sum
;
int
length
,
i
;
printk
(
KERN_INFO
"PnPBIOS: Scanning system for PnP BIOS support...
\n
"
);
/*
* Search the defined area (0xf0000-0xffff0) for a valid PnP BIOS
* structure and, if one is found, sets up the selectors and
* entry points
*/
for
(
check
=
(
union
pnp_bios_install_struct
*
)
__va
(
0xf0000
);
check
<
(
union
pnp_bios_install_struct
*
)
__va
(
0xffff0
);
((
void
*
)
(
check
))
+=
16
)
{
if
(
check
->
fields
.
signature
!=
PNP_SIGNATURE
)
continue
;
printk
(
KERN_INFO
"PnPBIOS: Found PnP BIOS installation structure at 0x%p
\n
"
,
check
);
length
=
check
->
fields
.
length
;
if
(
!
length
)
{
printk
(
KERN_ERR
"PnPBIOS: installation structure is invalid, skipping
\n
"
);
continue
;
}
for
(
sum
=
0
,
i
=
0
;
i
<
length
;
i
++
)
sum
+=
check
->
chars
[
i
];
if
(
sum
)
{
printk
(
KERN_ERR
"PnPBIOS: installation structure is corrupted, skipping
\n
"
);
continue
;
}
if
(
check
->
fields
.
version
<
0x10
)
{
printk
(
KERN_WARNING
"PnPBIOS: PnP BIOS version %d.%d is not supported
\n
"
,
check
->
fields
.
version
>>
4
,
check
->
fields
.
version
&
15
);
continue
;
}
printk
(
KERN_INFO
"PnPBIOS: PnP BIOS version %d.%d, entry 0x%x:0x%x, dseg 0x%x
\n
"
,
check
->
fields
.
version
>>
4
,
check
->
fields
.
version
&
15
,
check
->
fields
.
pm16cseg
,
check
->
fields
.
pm16offset
,
check
->
fields
.
pm16dseg
);
pnp_bios_install
=
check
;
return
1
;
}
printk
(
KERN_INFO
"PnPBIOS: PnP BIOS support was not detected.
\n
"
);
return
0
;
}
int
__init
pnpbios_init
(
void
)
{
...
...
@@ -421,9 +477,12 @@ int __init pnpbios_init(void)
}
/* scan the system for pnpbios support */
if
(
!
pnpbios_probe_
installation
())
if
(
!
pnpbios_probe_
system
())
return
-
ENODEV
;
/* make preparations for bios calls */
pnpbios_calls_init
(
pnp_bios_install
);
/* read the node info */
if
(
pnp_bios_dev_node_info
(
&
node_info
))
{
printk
(
KERN_ERR
"PnPBIOS: Unable to get node info. Aborting.
\n
"
);
...
...
@@ -447,6 +506,8 @@ int __init pnpbios_init(void)
return
0
;
}
subsys_initcall
(
pnpbios_init
);
static
int
__init
pnpbios_thread_init
(
void
)
{
#ifdef CONFIG_HOTPLUG
...
...
drivers/pnp/pnpbios/pnpbios.h
View file @
af0cf44c
/*
* pnpbios.h - contains
definitions for functions used only locally.
* pnpbios.h - contains
local definitions
*/
#pragma pack(1)
union
pnp_bios_install_struct
{
struct
{
u32
signature
;
/* "$PnP" */
u8
version
;
/* in BCD */
u8
length
;
/* length in bytes, currently 21h */
u16
control
;
/* system capabilities */
u8
checksum
;
/* all bytes must add up to 0 */
u32
eventflag
;
/* phys. address of the event flag */
u16
rmoffset
;
/* real mode entry point */
u16
rmcseg
;
u16
pm16offset
;
/* 16 bit protected mode entry */
u32
pm16cseg
;
u32
deviceID
;
/* EISA encoded system ID or 0 */
u16
rmdseg
;
/* real mode data segment */
u32
pm16dseg
;
/* 16 bit pm data segment base */
}
fields
;
char
chars
[
0x21
];
/* To calculate the checksum */
};
#pragma pack()
extern
int
pnp_bios_present
(
void
);
extern
int
pnpbios_parse_data_stream
(
struct
pnp_dev
*
dev
,
struct
pnp_bios_node
*
node
);
extern
int
pnpbios_read_resources_from_node
(
struct
pnp_resource_table
*
res
,
struct
pnp_bios_node
*
node
);
extern
int
pnpbios_write_resources_to_node
(
struct
pnp_resource_table
*
res
,
struct
pnp_bios_node
*
node
);
extern
void
pnpid32_to_pnpid
(
u32
id
,
char
*
str
);
extern
void
pnpbios_print_status
(
const
char
*
module
,
u16
status
);
extern
int
pnpbios_probe_installation
(
void
);
extern
void
pnpbios_calls_init
(
union
pnp_bios_install_struct
*
header
);
#ifdef CONFIG_PROC_FS
extern
int
pnpbios_interface_attach_device
(
struct
pnp_bios_node
*
node
);
...
...
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