2009-04-27 19:50:23 +02:00
# include "amd64_edac.h"
2010-09-02 18:33:24 +02:00
# define EDAC_DCT_ATTR_SHOW(reg) \
2012-03-21 14:00:44 -03:00
static ssize_t amd64_ # # reg # # _show ( struct device * dev , \
struct device_attribute * mattr , \
char * data ) \
2010-09-02 18:33:24 +02:00
{ \
2012-03-21 14:00:44 -03:00
struct mem_ctl_info * mci = to_mci ( dev ) ; \
2010-09-02 18:33:24 +02:00
struct amd64_pvt * pvt = mci - > pvt_info ; \
return sprintf ( data , " 0x%016llx \n " , ( u64 ) pvt - > reg ) ; \
2009-04-27 19:50:23 +02:00
}
2010-09-02 18:33:24 +02:00
EDAC_DCT_ATTR_SHOW ( dhar ) ;
EDAC_DCT_ATTR_SHOW ( dbam0 ) ;
EDAC_DCT_ATTR_SHOW ( top_mem ) ;
EDAC_DCT_ATTR_SHOW ( top_mem2 ) ;
2009-04-27 19:50:23 +02:00
2012-03-21 14:00:44 -03:00
static ssize_t amd64_hole_show ( struct device * dev ,
struct device_attribute * mattr ,
char * data )
2009-04-27 19:50:23 +02:00
{
2012-03-21 14:00:44 -03:00
struct mem_ctl_info * mci = to_mci ( dev ) ;
2009-04-27 19:50:23 +02:00
u64 hole_base = 0 ;
u64 hole_offset = 0 ;
u64 hole_size = 0 ;
amd64_get_dram_hole_info ( mci , & hole_base , & hole_offset , & hole_size ) ;
return sprintf ( data , " %llx %llx %llx \n " , hole_base , hole_offset ,
hole_size ) ;
}
/*
* update NUM_DBG_ATTRS in case you add new members
*/
2012-03-21 14:00:44 -03:00
static DEVICE_ATTR ( dhar , S_IRUGO , amd64_dhar_show , NULL ) ;
static DEVICE_ATTR ( dbam , S_IRUGO , amd64_dbam0_show , NULL ) ;
static DEVICE_ATTR ( topmem , S_IRUGO , amd64_top_mem_show , NULL ) ;
static DEVICE_ATTR ( topmem2 , S_IRUGO , amd64_top_mem2_show , NULL ) ;
static DEVICE_ATTR ( dram_hole , S_IRUGO , amd64_hole_show , NULL ) ;
2015-02-04 11:48:53 +01:00
static struct attribute * amd64_edac_dbg_attrs [ ] = {
& dev_attr_dhar . attr ,
& dev_attr_dbam . attr ,
& dev_attr_topmem . attr ,
& dev_attr_topmem2 . attr ,
& dev_attr_dram_hole . attr ,
NULL
} ;
const struct attribute_group amd64_edac_dbg_group = {
. attrs = amd64_edac_dbg_attrs ,
} ;