2005-04-16 15:20:36 -07:00
/*
* Compaq Hot Plug Controller Driver
*
* Copyright ( c ) 1995 , 2001 Compaq Computer Corporation
* Copyright ( c ) 2001 , 2003 Greg Kroah - Hartman ( greg @ kroah . com )
* Copyright ( c ) 2001 IBM Corp .
*
* All rights reserved .
*
* 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 , GOOD TITLE or
* NON INFRINGEMENT . 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 . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*
* Send feedback to < greg @ kroah . com >
*
*/
# include <linux/module.h>
# include <linux/kernel.h>
# include <linux/types.h>
# include <linux/pci.h>
# include "shpchp.h"
/* A few routines that create sysfs entries for the hot plug controller */
2005-05-17 06:42:58 -04:00
static ssize_t show_ctrl ( struct device * dev , struct device_attribute * attr , char * buf )
2005-04-16 15:20:36 -07:00
{
2005-10-13 12:05:36 -07:00
struct pci_dev * pdev ;
2005-04-16 15:20:36 -07:00
char * out = buf ;
2005-10-13 12:05:36 -07:00
int index , busnr ;
struct resource * res ;
struct pci_bus * bus ;
2005-04-16 15:20:36 -07:00
2005-10-13 12:05:36 -07:00
pdev = container_of ( dev , struct pci_dev , dev ) ;
bus = pdev - > subordinate ;
2005-04-16 15:20:36 -07:00
out + = sprintf ( buf , " Free resources: memory \n " ) ;
2010-02-23 10:24:31 -07:00
pci_bus_for_each_resource ( bus , res , index ) {
2005-10-13 12:05:36 -07:00
if ( res & & ( res - > flags & IORESOURCE_MEM ) & &
! ( res - > flags & IORESOURCE_PREFETCH ) ) {
2006-06-12 15:14:29 -07:00
out + = sprintf ( out , " start = %8.8llx, "
" length = %8.8llx \n " ,
( unsigned long long ) res - > start ,
( unsigned long long ) ( res - > end - res - > start ) ) ;
2005-10-13 12:05:36 -07:00
}
2005-04-16 15:20:36 -07:00
}
out + = sprintf ( out , " Free resources: prefetchable memory \n " ) ;
2010-02-23 10:24:31 -07:00
pci_bus_for_each_resource ( bus , res , index ) {
2005-10-13 12:05:36 -07:00
if ( res & & ( res - > flags & IORESOURCE_MEM ) & &
( res - > flags & IORESOURCE_PREFETCH ) ) {
2006-06-12 15:14:29 -07:00
out + = sprintf ( out , " start = %8.8llx, "
" length = %8.8llx \n " ,
( unsigned long long ) res - > start ,
( unsigned long long ) ( res - > end - res - > start ) ) ;
2005-10-13 12:05:36 -07:00
}
2005-04-16 15:20:36 -07:00
}
out + = sprintf ( out , " Free resources: IO \n " ) ;
2010-02-23 10:24:31 -07:00
pci_bus_for_each_resource ( bus , res , index ) {
2005-10-13 12:05:36 -07:00
if ( res & & ( res - > flags & IORESOURCE_IO ) ) {
2006-06-12 15:14:29 -07:00
out + = sprintf ( out , " start = %8.8llx, "
" length = %8.8llx \n " ,
( unsigned long long ) res - > start ,
( unsigned long long ) ( res - > end - res - > start ) ) ;
2005-10-13 12:05:36 -07:00
}
2005-04-16 15:20:36 -07:00
}
out + = sprintf ( out , " Free resources: bus numbers \n " ) ;
2005-10-13 12:05:36 -07:00
for ( busnr = bus - > secondary ; busnr < = bus - > subordinate ; busnr + + ) {
if ( ! pci_find_bus ( pci_domain_nr ( bus ) , busnr ) )
break ;
2005-04-16 15:20:36 -07:00
}
2005-10-13 12:05:36 -07:00
if ( busnr < bus - > subordinate )
out + = sprintf ( out , " start = %8.8x, length = %8.8x \n " ,
busnr , ( bus - > subordinate - busnr ) ) ;
2005-04-16 15:20:36 -07:00
return out - buf ;
}
static DEVICE_ATTR ( ctrl , S_IRUGO , show_ctrl , NULL ) ;
2006-08-28 11:43:25 -07:00
int __must_check shpchp_create_ctrl_files ( struct controller * ctrl )
2005-04-16 15:20:36 -07:00
{
2006-08-28 11:43:25 -07:00
return device_create_file ( & ctrl - > pci_dev - > dev , & dev_attr_ctrl ) ;
2005-04-16 15:20:36 -07:00
}
2005-10-13 12:05:44 -07:00
void shpchp_remove_ctrl_files ( struct controller * ctrl )
{
device_remove_file ( & ctrl - > pci_dev - > dev , & dev_attr_ctrl ) ;
}