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
a23d9f9b
Commit
a23d9f9b
authored
Jul 29, 2002
by
Tim Hockin
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://tux.sfbay/linux-2.5
into scl1.sfbay.sun.com:/home/th122948/bk/linux-2.5
parents
13e895aa
e1cd9bad
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
273 additions
and
263 deletions
+273
-263
drivers/char/nvram.c
drivers/char/nvram.c
+273
-263
No files found.
drivers/char/nvram.c
View file @
a23d9f9b
...
@@ -109,46 +109,50 @@
...
@@ -109,46 +109,50 @@
static
int
nvram_open_cnt
;
/* #times opened */
static
int
nvram_open_cnt
;
/* #times opened */
static
int
nvram_open_mode
;
/* special open modes */
static
int
nvram_open_mode
;
/* special open modes */
static
spinlock_t
nvram_open_lock
=
SPIN_LOCK_UNLOCKED
;
static
spinlock_t
nvram_open_lock
=
SPIN_LOCK_UNLOCKED
;
/* guards
/* guards
nvram_open_cnt and
*
nvram_open_cnt and
nvram_open_mode */
*
nvram_open_mode */
#define NVRAM_WRITE 1
/* opened for writing (exclusive) */
#define NVRAM_WRITE 1
/* opened for writing (exclusive) */
#define NVRAM_EXCL 2
/* opened with O_EXCL */
#define NVRAM_EXCL 2
/* opened with O_EXCL */
#define RTC_FIRST_BYTE 14
/* RTC register number of first NVRAM byte */
#define RTC_FIRST_BYTE 14
/* RTC register number of first
* NVRAM byte */
#define NVRAM_BYTES 128-RTC_FIRST_BYTE
/* number of NVRAM bytes */
#define NVRAM_BYTES 128-RTC_FIRST_BYTE
/* number of NVRAM bytes */
static
int
mach_check_checksum
(
void
);
static
void
mach_set_checksum
(
void
);
static
int
mach_check_checksum
(
void
);
static
void
mach_set_checksum
(
void
);
#ifdef CONFIG_PROC_FS
#ifdef CONFIG_PROC_FS
static
int
mach_proc_infos
(
unsigned
char
*
contents
,
char
*
buffer
,
int
*
len
,
static
int
mach_proc_infos
(
unsigned
char
*
contents
,
char
*
buffer
,
int
*
len
,
off_t
*
begin
,
off_t
offset
,
int
size
);
off_t
*
begin
,
off_t
offset
,
int
size
);
#endif
#endif
/*
/*
* These are the internal NVRAM access functions, which do NOT disable
* These are the internal NVRAM access functions, which do NOT disable
* interrupts and do not check the checksum. Both tasks are left to higher
* interrupts and do not check the checksum. Both tasks are left to higher
* level function, so they need to be done only once per syscall.
* level function, so they need to be done only once per syscall.
*/
*/
static
__inline__
unsigned
char
nvram_read_int
(
int
i
)
static
__inline__
unsigned
char
nvram_read_int
(
int
i
)
{
{
return
(
CMOS_READ
(
RTC_FIRST_BYTE
+
i
)
);
return
(
CMOS_READ
(
RTC_FIRST_BYTE
+
i
)
);
}
}
static
__inline__
void
nvram_write_int
(
unsigned
char
c
,
int
i
)
static
__inline__
void
nvram_write_int
(
unsigned
char
c
,
int
i
)
{
{
CMOS_WRITE
(
c
,
RTC_FIRST_BYTE
+
i
);
CMOS_WRITE
(
c
,
RTC_FIRST_BYTE
+
i
);
}
}
static
__inline__
int
nvram_check_checksum_int
(
void
)
static
__inline__
int
nvram_check_checksum_int
(
void
)
{
{
return
(
mach_check_checksum
()
);
return
(
mach_check_checksum
()
);
}
}
static
__inline__
void
nvram_set_checksum_int
(
void
)
static
__inline__
void
nvram_set_checksum_int
(
void
)
{
{
mach_set_checksum
();
mach_set_checksum
();
}
}
...
@@ -166,58 +170,62 @@ static __inline__ void nvram_set_checksum_int( void )
...
@@ -166,58 +170,62 @@ static __inline__ void nvram_set_checksum_int( void )
* module), so they access config information themselves.
* module), so they access config information themselves.
*/
*/
unsigned
char
nvram_read_byte
(
int
i
)
unsigned
char
nvram_read_byte
(
int
i
)
{
{
unsigned
long
flags
;
unsigned
long
flags
;
unsigned
char
c
;
unsigned
char
c
;
spin_lock_irqsave
(
&
rtc_lock
,
flags
);
spin_lock_irqsave
(
&
rtc_lock
,
flags
);
c
=
nvram_read_int
(
i
);
c
=
nvram_read_int
(
i
);
spin_unlock_irqrestore
(
&
rtc_lock
,
flags
);
spin_unlock_irqrestore
(
&
rtc_lock
,
flags
);
return
(
c
);
return
(
c
);
}
}
/* This races nicely with trying to read with checksum checking (nvram_read) */
/* This races nicely with trying to read with checksum checking (nvram_read) */
void
nvram_write_byte
(
unsigned
char
c
,
int
i
)
void
nvram_write_byte
(
unsigned
char
c
,
int
i
)
{
{
unsigned
long
flags
;
unsigned
long
flags
;
spin_lock_irqsave
(
&
rtc_lock
,
flags
);
spin_lock_irqsave
(
&
rtc_lock
,
flags
);
nvram_write_int
(
c
,
i
);
nvram_write_int
(
c
,
i
);
spin_unlock_irqrestore
(
&
rtc_lock
,
flags
);
spin_unlock_irqrestore
(
&
rtc_lock
,
flags
);
}
}
int
nvram_check_checksum
(
void
)
int
nvram_check_checksum
(
void
)
{
{
unsigned
long
flags
;
unsigned
long
flags
;
int
rv
;
int
rv
;
spin_lock_irqsave
(
&
rtc_lock
,
flags
);
spin_lock_irqsave
(
&
rtc_lock
,
flags
);
rv
=
nvram_check_checksum_int
();
rv
=
nvram_check_checksum_int
();
spin_unlock_irqrestore
(
&
rtc_lock
,
flags
);
spin_unlock_irqrestore
(
&
rtc_lock
,
flags
);
return
(
rv
);
return
(
rv
);
}
}
void
nvram_set_checksum
(
void
)
void
nvram_set_checksum
(
void
)
{
{
unsigned
long
flags
;
unsigned
long
flags
;
spin_lock_irqsave
(
&
rtc_lock
,
flags
);
spin_lock_irqsave
(
&
rtc_lock
,
flags
);
nvram_set_checksum_int
();
nvram_set_checksum_int
();
spin_unlock_irqrestore
(
&
rtc_lock
,
flags
);
spin_unlock_irqrestore
(
&
rtc_lock
,
flags
);
}
}
#endif
/* MACH == ATARI */
#endif
/* MACH == ATARI */
/*
/*
* The are the file operation function for user access to /dev/nvram
* The are the file operation function for user access to /dev/nvram
*/
*/
static
long
long
nvram_llseek
(
struct
file
*
file
,
loff_t
offset
,
int
origin
)
static
long
long
nvram_llseek
(
struct
file
*
file
,
loff_t
offset
,
int
origin
)
{
{
lock_kernel
();
lock_kernel
();
switch
(
origin
)
{
switch
(
origin
)
{
case
0
:
case
0
:
/* nothing to do */
/* nothing to do */
break
;
break
;
...
@@ -229,17 +237,17 @@ static long long nvram_llseek(struct file *file,loff_t offset, int origin )
...
@@ -229,17 +237,17 @@ static long long nvram_llseek(struct file *file,loff_t offset, int origin )
break
;
break
;
}
}
unlock_kernel
();
unlock_kernel
();
return
(
(
offset
>=
0
)
?
(
file
->
f_pos
=
offset
)
:
-
EINVAL
);
return
((
offset
>=
0
)
?
(
file
->
f_pos
=
offset
)
:
-
EINVAL
);
}
}
static
ssize_t
nvram_read
(
struct
file
*
file
,
static
ssize_t
char
*
buf
,
size_t
count
,
loff_t
*
ppos
)
nvram_read
(
struct
file
*
file
,
char
*
buf
,
size_t
count
,
loff_t
*
ppos
)
{
{
char
contents
[
NVRAM_BYTES
];
char
contents
[
NVRAM_BYTES
];
unsigned
i
=
*
ppos
;
unsigned
i
=
*
ppos
;
char
*
tmp
;
char
*
tmp
;
spin_lock_irq
(
&
rtc_lock
);
spin_lock_irq
(
&
rtc_lock
);
if
(
!
nvram_check_checksum_int
())
if
(
!
nvram_check_checksum_int
())
goto
checksum_err
;
goto
checksum_err
;
...
@@ -247,97 +255,98 @@ static ssize_t nvram_read(struct file * file,
...
@@ -247,97 +255,98 @@ static ssize_t nvram_read(struct file * file,
for
(
tmp
=
contents
;
count
--
>
0
&&
i
<
NVRAM_BYTES
;
++
i
,
++
tmp
)
for
(
tmp
=
contents
;
count
--
>
0
&&
i
<
NVRAM_BYTES
;
++
i
,
++
tmp
)
*
tmp
=
nvram_read_int
(
i
);
*
tmp
=
nvram_read_int
(
i
);
spin_unlock_irq
(
&
rtc_lock
);
spin_unlock_irq
(
&
rtc_lock
);
if
(
copy_to_user
(
buf
,
contents
,
tmp
-
contents
))
if
(
copy_to_user
(
buf
,
contents
,
tmp
-
contents
))
return
-
EFAULT
;
return
-
EFAULT
;
*
ppos
=
i
;
*
ppos
=
i
;
return
(
tmp
-
contents
);
return
(
tmp
-
contents
);
checksum_err:
checksum_err:
spin_unlock_irq
(
&
rtc_lock
);
spin_unlock_irq
(
&
rtc_lock
);
return
-
EIO
;
return
-
EIO
;
}
}
static
ssize_t
nvram_write
(
struct
file
*
file
,
static
ssize_t
const
char
*
buf
,
size_t
count
,
loff_t
*
ppos
)
nvram_write
(
struct
file
*
file
,
const
char
*
buf
,
size_t
count
,
loff_t
*
ppos
)
{
{
char
contents
[
NVRAM_BYTES
];
char
contents
[
NVRAM_BYTES
];
unsigned
i
=
*
ppos
;
unsigned
i
=
*
ppos
;
char
*
tmp
;
char
*
tmp
;
if
(
copy_from_user
(
contents
,
buf
,
(
NVRAM_BYTES
-
i
)
<
count
?
if
(
copy_from_user
(
contents
,
buf
,
(
NVRAM_BYTES
-
i
)
<
count
?
(
NVRAM_BYTES
-
i
)
:
count
))
(
NVRAM_BYTES
-
i
)
:
count
))
return
-
EFAULT
;
return
-
EFAULT
;
spin_lock_irq
(
&
rtc_lock
);
spin_lock_irq
(
&
rtc_lock
);
if
(
!
nvram_check_checksum_int
())
if
(
!
nvram_check_checksum_int
())
goto
checksum_err
;
goto
checksum_err
;
for
(
tmp
=
contents
;
count
--
>
0
&&
i
<
NVRAM_BYTES
;
++
i
,
++
tmp
)
for
(
tmp
=
contents
;
count
--
>
0
&&
i
<
NVRAM_BYTES
;
++
i
,
++
tmp
)
nvram_write_int
(
*
tmp
,
i
);
nvram_write_int
(
*
tmp
,
i
);
nvram_set_checksum_int
();
nvram_set_checksum_int
();
spin_unlock_irq
(
&
rtc_lock
);
spin_unlock_irq
(
&
rtc_lock
);
*
ppos
=
i
;
*
ppos
=
i
;
return
(
tmp
-
contents
);
return
(
tmp
-
contents
);
checksum_err:
checksum_err:
spin_unlock_irq
(
&
rtc_lock
);
spin_unlock_irq
(
&
rtc_lock
);
return
-
EIO
;
return
-
EIO
;
}
}
static
int
nvram_ioctl
(
struct
inode
*
inode
,
struct
file
*
file
,
static
int
unsigned
int
cmd
,
unsigned
long
arg
)
nvram_ioctl
(
struct
inode
*
inode
,
struct
file
*
file
,
unsigned
int
cmd
,
unsigned
long
arg
)
{
{
int
i
;
int
i
;
switch
(
cmd
)
{
switch
(
cmd
)
{
case
NVRAM_INIT
:
/* initialize NVRAM contents and checksum */
case
NVRAM_INIT
:
/* initialize NVRAM contents and checksum */
if
(
!
capable
(
CAP_SYS_ADMIN
))
if
(
!
capable
(
CAP_SYS_ADMIN
))
return
(
-
EACCES
);
return
(
-
EACCES
);
spin_lock_irq
(
&
rtc_lock
);
spin_lock_irq
(
&
rtc_lock
);
for
(
i
=
0
;
i
<
NVRAM_BYTES
;
++
i
)
for
(
i
=
0
;
i
<
NVRAM_BYTES
;
++
i
)
nvram_write_int
(
0
,
i
);
nvram_write_int
(
0
,
i
);
nvram_set_checksum_int
();
nvram_set_checksum_int
();
spin_unlock_irq
(
&
rtc_lock
);
spin_unlock_irq
(
&
rtc_lock
);
return
(
0
);
return
(
0
);
case
NVRAM_SETCKS
:
/* just set checksum, contents unchanged
case
NVRAM_SETCKS
:
/* just set checksum, contents unchanged
* (maybe useful after checksum garbaged
* (maybe useful after checksum garbaged
* somehow...) */
* somehow...) */
if
(
!
capable
(
CAP_SYS_ADMIN
))
if
(
!
capable
(
CAP_SYS_ADMIN
))
return
(
-
EACCES
);
return
(
-
EACCES
);
spin_lock_irq
(
&
rtc_lock
);
spin_lock_irq
(
&
rtc_lock
);
nvram_set_checksum_int
();
nvram_set_checksum_int
();
spin_unlock_irq
(
&
rtc_lock
);
spin_unlock_irq
(
&
rtc_lock
);
return
(
0
);
return
(
0
);
default:
default:
return
(
-
ENOTTY
);
return
(
-
ENOTTY
);
}
}
}
}
static
int
nvram_open
(
struct
inode
*
inode
,
struct
file
*
file
)
static
int
nvram_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
{
spin_lock
(
&
nvram_open_lock
);
spin_lock
(
&
nvram_open_lock
);
if
((
nvram_open_cnt
&&
(
file
->
f_flags
&
O_EXCL
))
||
if
((
nvram_open_cnt
&&
(
file
->
f_flags
&
O_EXCL
))
||
(
nvram_open_mode
&
NVRAM_EXCL
)
||
(
nvram_open_mode
&
NVRAM_EXCL
)
||
((
file
->
f_mode
&
2
)
&&
(
nvram_open_mode
&
NVRAM_WRITE
)))
((
file
->
f_mode
&
2
)
&&
(
nvram_open_mode
&
NVRAM_WRITE
)))
{
{
spin_unlock
(
&
nvram_open_lock
);
spin_unlock
(
&
nvram_open_lock
);
return
(
-
EBUSY
);
return
(
-
EBUSY
);
}
}
if
(
file
->
f_flags
&
O_EXCL
)
if
(
file
->
f_flags
&
O_EXCL
)
...
@@ -345,46 +354,51 @@ static int nvram_open( struct inode *inode, struct file *file )
...
@@ -345,46 +354,51 @@ static int nvram_open( struct inode *inode, struct file *file )
if
(
file
->
f_mode
&
2
)
if
(
file
->
f_mode
&
2
)
nvram_open_mode
|=
NVRAM_WRITE
;
nvram_open_mode
|=
NVRAM_WRITE
;
nvram_open_cnt
++
;
nvram_open_cnt
++
;
spin_unlock
(
&
nvram_open_lock
);
spin_unlock
(
&
nvram_open_lock
);
return
(
0
);
return
(
0
);
}
}
static
int
nvram_release
(
struct
inode
*
inode
,
struct
file
*
file
)
static
int
nvram_release
(
struct
inode
*
inode
,
struct
file
*
file
)
{
{
spin_lock
(
&
nvram_open_lock
);
spin_lock
(
&
nvram_open_lock
);
nvram_open_cnt
--
;
nvram_open_cnt
--
;
if
(
file
->
f_flags
&
O_EXCL
)
if
(
file
->
f_flags
&
O_EXCL
)
nvram_open_mode
&=
~
NVRAM_EXCL
;
nvram_open_mode
&=
~
NVRAM_EXCL
;
if
(
file
->
f_mode
&
2
)
if
(
file
->
f_mode
&
2
)
nvram_open_mode
&=
~
NVRAM_WRITE
;
nvram_open_mode
&=
~
NVRAM_WRITE
;
spin_unlock
(
&
nvram_open_lock
);
spin_unlock
(
&
nvram_open_lock
);
return
(
0
);
return
(
0
);
}
}
#ifndef CONFIG_PROC_FS
#ifndef CONFIG_PROC_FS
static
int
nvram_read_proc
(
char
*
buffer
,
char
**
start
,
off_t
offset
,
static
int
int
size
,
int
*
eof
,
void
*
data
)
{
return
0
;
}
nvram_read_proc
(
char
*
buffer
,
char
**
start
,
off_t
offset
,
int
size
,
int
*
eof
,
void
*
data
)
{
return
0
;
}
#else
#else
static
int
nvram_read_proc
(
char
*
buffer
,
char
**
start
,
off_t
offset
,
static
int
int
size
,
int
*
eof
,
void
*
data
)
nvram_read_proc
(
char
*
buffer
,
char
**
start
,
off_t
offset
,
int
size
,
int
*
eof
,
void
*
data
)
{
{
unsigned
char
contents
[
NVRAM_BYTES
];
unsigned
char
contents
[
NVRAM_BYTES
];
int
i
,
len
=
0
;
int
i
,
len
=
0
;
off_t
begin
=
0
;
off_t
begin
=
0
;
spin_lock_irq
(
&
rtc_lock
);
spin_lock_irq
(
&
rtc_lock
);
for
(
i
=
0
;
i
<
NVRAM_BYTES
;
++
i
)
for
(
i
=
0
;
i
<
NVRAM_BYTES
;
++
i
)
contents
[
i
]
=
nvram_read_int
(
i
);
contents
[
i
]
=
nvram_read_int
(
i
);
spin_unlock_irq
(
&
rtc_lock
);
spin_unlock_irq
(
&
rtc_lock
);
*
eof
=
mach_proc_infos
(
contents
,
buffer
,
&
len
,
&
begin
,
offset
,
size
);
*
eof
=
mach_proc_infos
(
contents
,
buffer
,
&
len
,
&
begin
,
offset
,
size
);
if
(
offset
>=
begin
+
len
)
if
(
offset
>=
begin
+
len
)
return
(
0
);
return
(
0
);
*
start
=
buffer
+
(
offset
-
begin
);
*
start
=
buffer
+
(
offset
-
begin
);
return
(
size
<
begin
+
len
-
offset
?
size
:
begin
+
len
-
offset
);
return
(
size
<
begin
+
len
-
offset
?
size
:
begin
+
len
-
offset
);
}
}
...
@@ -419,72 +433,75 @@ static struct miscdevice nvram_dev = {
...
@@ -419,72 +433,75 @@ static struct miscdevice nvram_dev = {
&
nvram_fops
&
nvram_fops
};
};
static
int
__init
static
int
__init
nvram_init
(
void
)
nvram_init
(
void
)
{
{
int
ret
;
int
ret
;
/* First test whether the driver should init at all */
/* First test whether the driver should init at all */
if
(
!
CHECK_DRIVER_INIT
())
if
(
!
CHECK_DRIVER_INIT
())
return
(
-
ENXIO
);
return
(
-
ENXIO
);
ret
=
misc_register
(
&
nvram_dev
);
ret
=
misc_register
(
&
nvram_dev
);
if
(
ret
)
{
if
(
ret
)
{
printk
(
KERN_ERR
"nvram: can't misc_register on minor=%d
\n
"
,
NVRAM_MINOR
);
printk
(
KERN_ERR
"nvram: can't misc_register on minor=%d
\n
"
,
NVRAM_MINOR
);
goto
out
;
goto
out
;
}
}
if
(
!
create_proc_read_entry
(
"driver/nvram"
,
0
,
0
,
nvram_read_proc
,
NULL
))
{
if
(
!
create_proc_read_entry
(
"driver/nvram"
,
0
,
0
,
nvram_read_proc
,
NULL
))
{
printk
(
KERN_ERR
"nvram: can't create /proc/driver/nvram
\n
"
);
printk
(
KERN_ERR
"nvram: can't create /proc/driver/nvram
\n
"
);
ret
=
-
ENOMEM
;
ret
=
-
ENOMEM
;
goto
outmisc
;
goto
outmisc
;
}
}
ret
=
0
;
ret
=
0
;
printk
(
KERN_INFO
"Non-volatile memory driver v"
NVRAM_VERSION
"
\n
"
);
printk
(
KERN_INFO
"Non-volatile memory driver v"
NVRAM_VERSION
"
\n
"
);
out:
out:
return
(
ret
);
return
(
ret
);
outmisc:
outmisc:
misc_deregister
(
&
nvram_dev
);
misc_deregister
(
&
nvram_dev
);
goto
out
;
goto
out
;
}
}
static
void
__exit
nvram_cleanup_module
(
void
)
static
void
__exit
nvram_cleanup_module
(
void
)
{
{
remove_proc_entry
(
"driver/nvram"
,
0
);
remove_proc_entry
(
"driver/nvram"
,
0
);
misc_deregister
(
&
nvram_dev
);
misc_deregister
(
&
nvram_dev
);
}
}
module_init
(
nvram_init
);
module_init
(
nvram_init
);
module_exit
(
nvram_cleanup_module
);
module_exit
(
nvram_cleanup_module
);
/*
/*
* Machine specific functions
* Machine specific functions
*/
*/
#if MACH == PC
#if MACH == PC
static
int
pc_check_checksum
(
void
)
static
int
pc_check_checksum
(
void
)
{
{
int
i
;
int
i
;
unsigned
short
sum
=
0
;
unsigned
short
sum
=
0
;
for
(
i
=
PC_CKS_RANGE_START
;
i
<=
PC_CKS_RANGE_END
;
++
i
)
for
(
i
=
PC_CKS_RANGE_START
;
i
<=
PC_CKS_RANGE_END
;
++
i
)
sum
+=
nvram_read_int
(
i
);
sum
+=
nvram_read_int
(
i
);
return
(
(
sum
&
0xffff
)
==
return
(
(
sum
&
0xffff
)
==
((
nvram_read_int
(
PC_CKS_LOC
)
<<
8
)
|
((
nvram_read_int
(
PC_CKS_LOC
)
<<
8
)
|
nvram_read_int
(
PC_CKS_LOC
+
1
))
);
nvram_read_int
(
PC_CKS_LOC
+
1
))
);
}
}
static
void
pc_set_checksum
(
void
)
static
void
pc_set_checksum
(
void
)
{
{
int
i
;
int
i
;
unsigned
short
sum
=
0
;
unsigned
short
sum
=
0
;
for
(
i
=
PC_CKS_RANGE_START
;
i
<=
PC_CKS_RANGE_END
;
++
i
)
for
(
i
=
PC_CKS_RANGE_START
;
i
<=
PC_CKS_RANGE_END
;
++
i
)
sum
+=
nvram_read_int
(
i
);
sum
+=
nvram_read_int
(
i
);
nvram_write_int
(
sum
>>
8
,
PC_CKS_LOC
);
nvram_write_int
(
sum
>>
8
,
PC_CKS_LOC
);
nvram_write_int
(
sum
&
0xff
,
PC_CKS_LOC
+
1
);
nvram_write_int
(
sum
&
0xff
,
PC_CKS_LOC
+
1
);
}
}
#ifdef CONFIG_PROC_FS
#ifdef CONFIG_PROC_FS
...
@@ -501,69 +518,67 @@ static char *gfx_types[] = {
...
@@ -501,69 +518,67 @@ static char *gfx_types[] = {
"monochrome"
,
"monochrome"
,
};
};
static
int
pc_proc_infos
(
unsigned
char
*
nvram
,
char
*
buffer
,
int
*
len
,
static
int
off_t
*
begin
,
off_t
offset
,
int
size
)
pc_proc_infos
(
unsigned
char
*
nvram
,
char
*
buffer
,
int
*
len
,
off_t
*
begin
,
off_t
offset
,
int
size
)
{
{
int
checksum
;
int
checksum
;
int
type
;
int
type
;
spin_lock_irq
(
&
rtc_lock
);
spin_lock_irq
(
&
rtc_lock
);
checksum
=
nvram_check_checksum_int
();
checksum
=
nvram_check_checksum_int
();
spin_unlock_irq
(
&
rtc_lock
);
spin_unlock_irq
(
&
rtc_lock
);
PRINT_PROC
(
"Checksum status: %svalid
\n
"
,
checksum
?
""
:
"not "
);
PRINT_PROC
(
"Checksum status: %svalid
\n
"
,
checksum
?
""
:
"not "
);
PRINT_PROC
(
"# floppies : %d
\n
"
,
PRINT_PROC
(
"# floppies : %d
\n
"
,
(
nvram
[
6
]
&
1
)
?
(
nvram
[
6
]
>>
6
)
+
1
:
0
);
(
nvram
[
6
]
&
1
)
?
(
nvram
[
6
]
>>
6
)
+
1
:
0
);
PRINT_PROC
(
"Floppy 0 type : "
);
PRINT_PROC
(
"Floppy 0 type : "
);
type
=
nvram
[
2
]
>>
4
;
type
=
nvram
[
2
]
>>
4
;
if
(
type
<
sizeof
(
floppy_types
)
/
sizeof
(
*
floppy_types
))
if
(
type
<
sizeof
(
floppy_types
)
/
sizeof
(
*
floppy_types
))
PRINT_PROC
(
"%s
\n
"
,
floppy_types
[
type
]
);
PRINT_PROC
(
"%s
\n
"
,
floppy_types
[
type
]
);
else
else
PRINT_PROC
(
"%d (unknown)
\n
"
,
type
);
PRINT_PROC
(
"%d (unknown)
\n
"
,
type
);
PRINT_PROC
(
"Floppy 1 type : "
);
PRINT_PROC
(
"Floppy 1 type : "
);
type
=
nvram
[
2
]
&
0x0f
;
type
=
nvram
[
2
]
&
0x0f
;
if
(
type
<
sizeof
(
floppy_types
)
/
sizeof
(
*
floppy_types
))
if
(
type
<
sizeof
(
floppy_types
)
/
sizeof
(
*
floppy_types
))
PRINT_PROC
(
"%s
\n
"
,
floppy_types
[
type
]
);
PRINT_PROC
(
"%s
\n
"
,
floppy_types
[
type
]
);
else
else
PRINT_PROC
(
"%d (unknown)
\n
"
,
type
);
PRINT_PROC
(
"%d (unknown)
\n
"
,
type
);
PRINT_PROC
(
"HD 0 type : "
);
PRINT_PROC
(
"HD 0 type : "
);
type
=
nvram
[
4
]
>>
4
;
type
=
nvram
[
4
]
>>
4
;
if
(
type
)
if
(
type
)
PRINT_PROC
(
"%02x
\n
"
,
type
==
0x0f
?
nvram
[
11
]
:
type
);
PRINT_PROC
(
"%02x
\n
"
,
type
==
0x0f
?
nvram
[
11
]
:
type
);
else
else
PRINT_PROC
(
"none
\n
"
);
PRINT_PROC
(
"none
\n
"
);
PRINT_PROC
(
"HD 1 type : "
);
PRINT_PROC
(
"HD 1 type : "
);
type
=
nvram
[
4
]
&
0x0f
;
type
=
nvram
[
4
]
&
0x0f
;
if
(
type
)
if
(
type
)
PRINT_PROC
(
"%02x
\n
"
,
type
==
0x0f
?
nvram
[
12
]
:
type
);
PRINT_PROC
(
"%02x
\n
"
,
type
==
0x0f
?
nvram
[
12
]
:
type
);
else
else
PRINT_PROC
(
"none
\n
"
);
PRINT_PROC
(
"none
\n
"
);
PRINT_PROC
(
"HD type 48 data: %d/%d/%d C/H/S, precomp %d, lz %d
\n
"
,
PRINT_PROC
(
"HD type 48 data: %d/%d/%d C/H/S, precomp %d, lz %d
\n
"
,
nvram
[
18
]
|
(
nvram
[
19
]
<<
8
),
nvram
[
18
]
|
(
nvram
[
19
]
<<
8
),
nvram
[
20
],
nvram
[
25
],
nvram
[
20
],
nvram
[
25
],
nvram
[
21
]
|
(
nvram
[
22
]
<<
8
),
nvram
[
21
]
|
(
nvram
[
22
]
<<
8
),
nvram
[
23
]
|
(
nvram
[
24
]
<<
8
));
nvram
[
23
]
|
(
nvram
[
24
]
<<
8
)
);
PRINT_PROC
(
"HD type 49 data: %d/%d/%d C/H/S, precomp %d, lz %d
\n
"
,
PRINT_PROC
(
"HD type 49 data: %d/%d/%d C/H/S, precomp %d, lz %d
\n
"
,
nvram
[
39
]
|
(
nvram
[
40
]
<<
8
),
nvram
[
39
]
|
(
nvram
[
40
]
<<
8
),
nvram
[
41
],
nvram
[
46
],
nvram
[
41
],
nvram
[
46
],
nvram
[
42
]
|
(
nvram
[
43
]
<<
8
),
nvram
[
42
]
|
(
nvram
[
43
]
<<
8
),
nvram
[
44
]
|
(
nvram
[
45
]
<<
8
));
nvram
[
44
]
|
(
nvram
[
45
]
<<
8
)
);
PRINT_PROC
(
"DOS base memory: %d kB
\n
"
,
nvram
[
7
]
|
(
nvram
[
8
]
<<
8
)
);
PRINT_PROC
(
"DOS base memory: %d kB
\n
"
,
nvram
[
7
]
|
(
nvram
[
8
]
<<
8
));
PRINT_PROC
(
"Extended memory: %d kB (configured), %d kB (tested)
\n
"
,
PRINT_PROC
(
"Extended memory: %d kB (configured), %d kB (tested)
\n
"
,
nvram
[
9
]
|
(
nvram
[
10
]
<<
8
),
nvram
[
9
]
|
(
nvram
[
10
]
<<
8
),
nvram
[
34
]
|
(
nvram
[
35
]
<<
8
));
nvram
[
34
]
|
(
nvram
[
35
]
<<
8
)
);
PRINT_PROC
(
"Gfx adapter : %s
\n
"
,
gfx_types
[
(
nvram
[
6
]
>>
4
)
&
3
]
);
PRINT_PROC
(
"Gfx adapter : %s
\n
"
,
gfx_types
[(
nvram
[
6
]
>>
4
)
&
3
]
);
PRINT_PROC
(
"FPU : %sinstalled
\n
"
,
PRINT_PROC
(
"FPU : %sinstalled
\n
"
,
(
nvram
[
6
]
&
2
)
?
""
:
"not "
);
(
nvram
[
6
]
&
2
)
?
""
:
"not "
);
return
(
1
);
return
(
1
);
}
}
#endif
#endif
...
@@ -571,26 +586,28 @@ static int pc_proc_infos( unsigned char *nvram, char *buffer, int *len,
...
@@ -571,26 +586,28 @@ static int pc_proc_infos( unsigned char *nvram, char *buffer, int *len,
#if MACH == ATARI
#if MACH == ATARI
static
int
atari_check_checksum
(
void
)
static
int
atari_check_checksum
(
void
)
{
{
int
i
;
int
i
;
unsigned
char
sum
=
0
;
unsigned
char
sum
=
0
;
for
(
i
=
ATARI_CKS_RANGE_START
;
i
<=
ATARI_CKS_RANGE_END
;
++
i
)
for
(
i
=
ATARI_CKS_RANGE_START
;
i
<=
ATARI_CKS_RANGE_END
;
++
i
)
sum
+=
nvram_read_int
(
i
);
sum
+=
nvram_read_int
(
i
);
return
(
nvram_read_int
(
ATARI_CKS_LOC
)
==
(
~
sum
&
0xff
)
&&
return
(
nvram_read_int
(
ATARI_CKS_LOC
)
==
(
~
sum
&
0xff
)
&&
nvram_read_int
(
ATARI_CKS_LOC
+
1
)
==
(
sum
&
0xff
)
);
nvram_read_int
(
ATARI_CKS_LOC
+
1
)
==
(
sum
&
0xff
)
);
}
}
static
void
atari_set_checksum
(
void
)
static
void
atari_set_checksum
(
void
)
{
{
int
i
;
int
i
;
unsigned
char
sum
=
0
;
unsigned
char
sum
=
0
;
for
(
i
=
ATARI_CKS_RANGE_START
;
i
<=
ATARI_CKS_RANGE_END
;
++
i
)
for
(
i
=
ATARI_CKS_RANGE_START
;
i
<=
ATARI_CKS_RANGE_END
;
++
i
)
sum
+=
nvram_read_int
(
i
);
sum
+=
nvram_read_int
(
i
);
nvram_write_int
(
~
sum
,
ATARI_CKS_LOC
);
nvram_write_int
(
~
sum
,
ATARI_CKS_LOC
);
nvram_write_int
(
sum
,
ATARI_CKS_LOC
+
1
);
nvram_write_int
(
sum
,
ATARI_CKS_LOC
+
1
);
}
}
#ifdef CONFIG_PROC_FS
#ifdef CONFIG_PROC_FS
...
@@ -635,81 +652,74 @@ static char *colors[] = {
...
@@ -635,81 +652,74 @@ static char *colors[] = {
#define fieldsize(a) (sizeof(a)/sizeof(*a))
#define fieldsize(a) (sizeof(a)/sizeof(*a))
static
int
atari_proc_infos
(
unsigned
char
*
nvram
,
char
*
buffer
,
int
*
len
,
static
int
off_t
*
begin
,
off_t
offset
,
int
size
)
atari_proc_infos
(
unsigned
char
*
nvram
,
char
*
buffer
,
int
*
len
,
off_t
*
begin
,
off_t
offset
,
int
size
)
{
{
int
checksum
=
nvram_check_checksum
();
int
checksum
=
nvram_check_checksum
();
int
i
;
int
i
;
unsigned
vmode
;
unsigned
vmode
;
PRINT_PROC
(
"Checksum status : %svalid
\n
"
,
checksum
?
""
:
"not "
);
PRINT_PROC
(
"Checksum status : %svalid
\n
"
,
checksum
?
""
:
"not "
);
PRINT_PROC
(
"Boot preference : "
);
PRINT_PROC
(
"Boot preference : "
);
for
(
i
=
fieldsize
(
boot_prefs
)
-
1
;
i
>=
0
;
--
i
)
{
for
(
i
=
fieldsize
(
boot_prefs
)
-
1
;
i
>=
0
;
--
i
)
{
if
(
nvram
[
1
]
==
boot_prefs
[
i
].
val
)
{
if
(
nvram
[
1
]
==
boot_prefs
[
i
].
val
)
{
PRINT_PROC
(
"%s
\n
"
,
boot_prefs
[
i
].
name
);
PRINT_PROC
(
"%s
\n
"
,
boot_prefs
[
i
].
name
);
break
;
break
;
}
}
}
}
if
(
i
<
0
)
if
(
i
<
0
)
PRINT_PROC
(
"0x%02x (undefined)
\n
"
,
nvram
[
1
]
);
PRINT_PROC
(
"0x%02x (undefined)
\n
"
,
nvram
[
1
]
);
PRINT_PROC
(
"SCSI arbitration : %s
\n
"
,
(
nvram
[
16
]
&
0x80
)
?
"on"
:
"off"
);
PRINT_PROC
(
"SCSI arbitration : %s
\n
"
,
PRINT_PROC
(
"SCSI host ID : "
);
(
nvram
[
16
]
&
0x80
)
?
"on"
:
"off"
);
PRINT_PROC
(
"SCSI host ID : "
);
if
(
nvram
[
16
]
&
0x80
)
if
(
nvram
[
16
]
&
0x80
)
PRINT_PROC
(
"%d
\n
"
,
nvram
[
16
]
&
7
);
PRINT_PROC
(
"%d
\n
"
,
nvram
[
16
]
&
7
);
else
else
PRINT_PROC
(
"n/a
\n
"
);
PRINT_PROC
(
"n/a
\n
"
);
/* the following entries are defined only for the Falcon */
/* the following entries are defined only for the Falcon */
if
((
atari_mch_cookie
>>
16
)
!=
ATARI_MCH_FALCON
)
if
((
atari_mch_cookie
>>
16
)
!=
ATARI_MCH_FALCON
)
return
1
;
return
1
;
PRINT_PROC
(
"OS language : "
);
PRINT_PROC
(
"OS language : "
);
if
(
nvram
[
6
]
<
fieldsize
(
languages
))
if
(
nvram
[
6
]
<
fieldsize
(
languages
))
PRINT_PROC
(
"%s
\n
"
,
languages
[
nvram
[
6
]]
);
PRINT_PROC
(
"%s
\n
"
,
languages
[
nvram
[
6
]]
);
else
else
PRINT_PROC
(
"%u (undefined)
\n
"
,
nvram
[
6
]
);
PRINT_PROC
(
"%u (undefined)
\n
"
,
nvram
[
6
]
);
PRINT_PROC
(
"Keyboard language: "
);
PRINT_PROC
(
"Keyboard language: "
);
if
(
nvram
[
7
]
<
fieldsize
(
languages
))
if
(
nvram
[
7
]
<
fieldsize
(
languages
))
PRINT_PROC
(
"%s
\n
"
,
languages
[
nvram
[
7
]]
);
PRINT_PROC
(
"%s
\n
"
,
languages
[
nvram
[
7
]]
);
else
else
PRINT_PROC
(
"%u (undefined)
\n
"
,
nvram
[
7
]
);
PRINT_PROC
(
"%u (undefined)
\n
"
,
nvram
[
7
]
);
PRINT_PROC
(
"Date format : "
);
PRINT_PROC
(
"Date format : "
);
PRINT_PROC
(
dateformat
[
nvram
[
8
]
&
7
],
PRINT_PROC
(
dateformat
[
nvram
[
8
]
&
7
],
nvram
[
9
]
?
nvram
[
9
]
:
'/'
,
nvram
[
9
]
?
nvram
[
9
]
:
'/'
);
nvram
[
9
]
?
nvram
[
9
]
:
'/'
,
nvram
[
9
]
?
nvram
[
9
]
:
'/'
);
PRINT_PROC
(
", %dh clock
\n
"
,
nvram
[
8
]
&
16
?
24
:
12
);
PRINT_PROC
(
", %dh clock
\n
"
,
nvram
[
8
]
&
16
?
24
:
12
);
PRINT_PROC
(
"Boot delay : "
);
PRINT_PROC
(
"Boot delay : "
);
if
(
nvram
[
10
]
==
0
)
if
(
nvram
[
10
]
==
0
)
PRINT_PROC
(
"default"
);
PRINT_PROC
(
"default"
);
else
else
PRINT_PROC
(
"%ds%s
\n
"
,
nvram
[
10
],
PRINT_PROC
(
"%ds%s
\n
"
,
nvram
[
10
],
nvram
[
10
]
<
8
?
", no memory test"
:
""
);
nvram
[
10
]
<
8
?
", no memory test"
:
""
);
vmode
=
(
nvram
[
14
]
<<
8
)
||
nvram
[
15
];
vmode
=
(
nvram
[
14
]
<<
8
)
||
nvram
[
15
];
PRINT_PROC
(
"Video mode : %s colors, %d columns, %s %s monitor
\n
"
,
PRINT_PROC
(
"Video mode : %s colors, %d columns, %s %s monitor
\n
"
,
colors
[
vmode
&
7
],
colors
[
vmode
&
7
],
vmode
&
8
?
80
:
40
,
vmode
&
8
?
80
:
40
,
vmode
&
16
?
"VGA"
:
"TV"
,
vmode
&
16
?
"VGA"
:
"TV"
,
vmode
&
32
?
"PAL"
:
"NTSC"
);
vmode
&
32
?
"PAL"
:
"NTSC"
);
PRINT_PROC
(
" %soverscan, compat. mode %s%s
\n
"
,
PRINT_PROC
(
" %soverscan, compat. mode %s%s
\n
"
,
vmode
&
64
?
""
:
"no "
,
vmode
&
64
?
""
:
"no "
,
vmode
&
128
?
"on"
:
"off"
,
vmode
&
128
?
"on"
:
"off"
,
vmode
&
256
?
vmode
&
256
?
(
vmode
&
16
?
", line doubling"
:
", half screen"
)
:
""
);
(
vmode
&
16
?
", line doubling"
:
", half screen"
)
:
""
);
return
(
1
);
return
(
1
);
}
}
#endif
#endif
#endif
/* MACH == ATARI */
#endif
/* MACH == ATARI */
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
/*
* Local variables:
* c-indent-level: 4
* tab-width: 4
* End:
*/
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