2006-06-18 16:39:46 +01:00
/*
* Copyright ( C ) 2004 , 2005 by Basler Vision Technologies AG
* Author : Thomas Koeller < thomas . koeller @ baslerweb . com >
*
* Procfs support for Basler eXcite
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
2008-04-29 01:01:50 -07:00
# include <linux/module.h>
2006-06-18 16:39:46 +01:00
# include <linux/proc_fs.h>
2008-04-29 01:01:50 -07:00
# include <linux/seq_file.h>
2006-06-18 16:39:46 +01:00
# include <linux/stat.h>
# include <asm/page.h>
# include <asm/io.h>
# include <asm/system.h>
# include <asm/rm9k-ocd.h>
# include <excite.h>
2008-04-29 01:01:50 -07:00
static int excite_unit_id_proc_show ( struct seq_file * m , void * v )
2006-06-18 16:39:46 +01:00
{
2008-04-29 01:01:50 -07:00
seq_printf ( m , " %06x " , unit_id ) ;
return 0 ;
2006-06-18 16:39:46 +01:00
}
2008-04-29 01:01:50 -07:00
static int excite_unit_id_proc_open ( struct inode * inode , struct file * file )
{
return single_open ( file , excite_unit_id_proc_show , NULL ) ;
}
static const struct file_operations excite_unit_id_proc_fops = {
. owner = THIS_MODULE ,
. open = excite_unit_id_proc_open ,
. read = seq_read ,
. llseek = seq_lseek ,
. release = single_release ,
} ;
2006-06-18 16:39:46 +01:00
static int
excite_bootrom_read ( char * page , char * * start , off_t off , int count ,
int * eof , void * data )
{
void __iomem * src ;
if ( off > = EXCITE_SIZE_BOOTROM ) {
* eof = 1 ;
return 0 ;
}
if ( ( off + count ) > EXCITE_SIZE_BOOTROM )
count = EXCITE_SIZE_BOOTROM - off ;
src = ioremap ( EXCITE_PHYS_BOOTROM + off , count ) ;
if ( src ) {
memcpy_fromio ( page , src , count ) ;
iounmap ( src ) ;
* start = page ;
} else {
count = - ENOMEM ;
}
return count ;
}
void excite_procfs_init ( void )
{
/* Create & populate /proc/excite */
2008-04-29 01:01:44 -07:00
struct proc_dir_entry * const pdir = proc_mkdir ( " excite " , NULL ) ;
2006-06-18 16:39:46 +01:00
if ( pdir ) {
struct proc_dir_entry * e ;
2008-04-29 01:01:50 -07:00
e = proc_create ( " unit_id " , S_IRUGO , pdir ,
& excite_unit_id_proc_fops ) ;
2006-06-18 16:39:46 +01:00
if ( e ) e - > size = 6 ;
e = create_proc_read_entry ( " bootrom " , S_IRUGO , pdir ,
excite_bootrom_read , NULL ) ;
if ( e ) e - > size = EXCITE_SIZE_BOOTROM ;
}
}