2005-04-16 15:20:36 -07:00
/*
* / dev / nvram driver for Power Macintosh .
*/
# define NVRAM_VERSION "1.0"
# include <linux/module.h>
# include <linux/types.h>
# include <linux/errno.h>
# include <linux/fs.h>
# include <linux/miscdevice.h>
# include <linux/fcntl.h>
# include <linux/nvram.h>
# include <linux/init.h>
# include <asm/uaccess.h>
# include <asm/nvram.h>
# define NVRAM_SIZE 8192
static loff_t nvram_llseek ( struct file * file , loff_t offset , int origin )
{
switch ( origin ) {
2011-07-18 13:21:39 -04:00
case 0 :
break ;
2005-04-16 15:20:36 -07:00
case 1 :
offset + = file - > f_pos ;
break ;
case 2 :
offset + = NVRAM_SIZE ;
break ;
2011-07-18 13:21:39 -04:00
default :
offset = - 1 ;
2005-04-16 15:20:36 -07:00
}
2009-10-15 10:28:38 +00:00
if ( offset < 0 )
2005-04-16 15:20:36 -07:00
return - EINVAL ;
2009-10-15 10:28:38 +00:00
2005-04-16 15:20:36 -07:00
file - > f_pos = offset ;
return file - > f_pos ;
}
static ssize_t read_nvram ( struct file * file , char __user * buf ,
size_t count , loff_t * ppos )
{
unsigned int i ;
char __user * p = buf ;
if ( ! access_ok ( VERIFY_WRITE , buf , count ) )
return - EFAULT ;
if ( * ppos > = NVRAM_SIZE )
return 0 ;
for ( i = * ppos ; count > 0 & & i < NVRAM_SIZE ; + + i , + + p , - - count )
if ( __put_user ( nvram_read_byte ( i ) , p ) )
return - EFAULT ;
* ppos = i ;
return p - buf ;
}
static ssize_t write_nvram ( struct file * file , const char __user * buf ,
size_t count , loff_t * ppos )
{
unsigned int i ;
const char __user * p = buf ;
char c ;
if ( ! access_ok ( VERIFY_READ , buf , count ) )
return - EFAULT ;
if ( * ppos > = NVRAM_SIZE )
return 0 ;
for ( i = * ppos ; count > 0 & & i < NVRAM_SIZE ; + + i , + + p , - - count ) {
if ( __get_user ( c , p ) )
return - EFAULT ;
nvram_write_byte ( c , i ) ;
}
* ppos = i ;
return p - buf ;
}
2009-10-15 10:28:38 +00:00
static long nvram_ioctl ( struct file * file , unsigned int cmd , unsigned long arg )
2005-04-16 15:20:36 -07:00
{
switch ( cmd ) {
case PMAC_NVRAM_GET_OFFSET :
{
int part , offset ;
if ( copy_from_user ( & part , ( void __user * ) arg , sizeof ( part ) ) ! = 0 )
return - EFAULT ;
if ( part < pmac_nvram_OF | | part > pmac_nvram_NR )
return - EINVAL ;
offset = pmac_get_partition ( part ) ;
if ( copy_to_user ( ( void __user * ) arg , & offset , sizeof ( offset ) ) ! = 0 )
return - EFAULT ;
break ;
}
default :
return - EINVAL ;
}
return 0 ;
}
2007-02-12 00:55:33 -08:00
const struct file_operations nvram_fops = {
2005-04-16 15:20:36 -07:00
. owner = THIS_MODULE ,
. llseek = nvram_llseek ,
. read = read_nvram ,
. write = write_nvram ,
2010-04-27 00:24:05 +02:00
. unlocked_ioctl = nvram_ioctl ,
2005-04-16 15:20:36 -07:00
} ;
static struct miscdevice nvram_dev = {
NVRAM_MINOR ,
" nvram " ,
& nvram_fops
} ;
int __init nvram_init ( void )
{
printk ( KERN_INFO " Macintosh non-volatile memory driver v%s \n " ,
NVRAM_VERSION ) ;
return misc_register ( & nvram_dev ) ;
}
void __exit nvram_cleanup ( void )
{
misc_deregister ( & nvram_dev ) ;
}
module_init ( nvram_init ) ;
module_exit ( nvram_cleanup ) ;
MODULE_LICENSE ( " GPL " ) ;