powerpc: Define missing ppc_md.nvram_size for CHRP and PowerMac
Add the nvram_size() function to those PowerPC platforms that don't already have one: CHRP and PowerMac. This means that the ppc_md.nvram_size() function can be called by nvram_get_size(). Since we are addressing CHRP inconsistencies here, rename chrp_nvram_read and chrp_nvram_write, which break the naming convention used across powerpc platforms for NVRAM accessor functions. Tested-by: Stan Johnson <userm57@yahoo.com> Signed-off-by: Finn Thain <fthain@telegraphics.com.au> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
7fc0ac05f3
commit
ebcebc7f45
|
@ -24,7 +24,7 @@ static unsigned int nvram_size;
|
||||||
static unsigned char nvram_buf[4];
|
static unsigned char nvram_buf[4];
|
||||||
static DEFINE_SPINLOCK(nvram_lock);
|
static DEFINE_SPINLOCK(nvram_lock);
|
||||||
|
|
||||||
static unsigned char chrp_nvram_read(int addr)
|
static unsigned char chrp_nvram_read_val(int addr)
|
||||||
{
|
{
|
||||||
unsigned int done;
|
unsigned int done;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
@ -46,7 +46,7 @@ static unsigned char chrp_nvram_read(int addr)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void chrp_nvram_write(int addr, unsigned char val)
|
static void chrp_nvram_write_val(int addr, unsigned char val)
|
||||||
{
|
{
|
||||||
unsigned int done;
|
unsigned int done;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
@ -64,6 +64,11 @@ static void chrp_nvram_write(int addr, unsigned char val)
|
||||||
spin_unlock_irqrestore(&nvram_lock, flags);
|
spin_unlock_irqrestore(&nvram_lock, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static ssize_t chrp_nvram_size(void)
|
||||||
|
{
|
||||||
|
return nvram_size;
|
||||||
|
}
|
||||||
|
|
||||||
void __init chrp_nvram_init(void)
|
void __init chrp_nvram_init(void)
|
||||||
{
|
{
|
||||||
struct device_node *nvram;
|
struct device_node *nvram;
|
||||||
|
@ -85,8 +90,9 @@ void __init chrp_nvram_init(void)
|
||||||
printk(KERN_INFO "CHRP nvram contains %u bytes\n", nvram_size);
|
printk(KERN_INFO "CHRP nvram contains %u bytes\n", nvram_size);
|
||||||
of_node_put(nvram);
|
of_node_put(nvram);
|
||||||
|
|
||||||
ppc_md.nvram_read_val = chrp_nvram_read;
|
ppc_md.nvram_read_val = chrp_nvram_read_val;
|
||||||
ppc_md.nvram_write_val = chrp_nvram_write;
|
ppc_md.nvram_write_val = chrp_nvram_write_val;
|
||||||
|
ppc_md.nvram_size = chrp_nvram_size;
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -147,6 +147,11 @@ static ssize_t core99_nvram_size(void)
|
||||||
static volatile unsigned char __iomem *nvram_addr;
|
static volatile unsigned char __iomem *nvram_addr;
|
||||||
static int nvram_mult;
|
static int nvram_mult;
|
||||||
|
|
||||||
|
static ssize_t ppc32_nvram_size(void)
|
||||||
|
{
|
||||||
|
return NVRAM_SIZE;
|
||||||
|
}
|
||||||
|
|
||||||
static unsigned char direct_nvram_read_byte(int addr)
|
static unsigned char direct_nvram_read_byte(int addr)
|
||||||
{
|
{
|
||||||
return in_8(&nvram_data[(addr & (NVRAM_SIZE - 1)) * nvram_mult]);
|
return in_8(&nvram_data[(addr & (NVRAM_SIZE - 1)) * nvram_mult]);
|
||||||
|
@ -590,21 +595,25 @@ int __init pmac_nvram_init(void)
|
||||||
nvram_mult = 1;
|
nvram_mult = 1;
|
||||||
ppc_md.nvram_read_val = direct_nvram_read_byte;
|
ppc_md.nvram_read_val = direct_nvram_read_byte;
|
||||||
ppc_md.nvram_write_val = direct_nvram_write_byte;
|
ppc_md.nvram_write_val = direct_nvram_write_byte;
|
||||||
|
ppc_md.nvram_size = ppc32_nvram_size;
|
||||||
} else if (nvram_naddrs == 1) {
|
} else if (nvram_naddrs == 1) {
|
||||||
nvram_data = ioremap(r1.start, s1);
|
nvram_data = ioremap(r1.start, s1);
|
||||||
nvram_mult = (s1 + NVRAM_SIZE - 1) / NVRAM_SIZE;
|
nvram_mult = (s1 + NVRAM_SIZE - 1) / NVRAM_SIZE;
|
||||||
ppc_md.nvram_read_val = direct_nvram_read_byte;
|
ppc_md.nvram_read_val = direct_nvram_read_byte;
|
||||||
ppc_md.nvram_write_val = direct_nvram_write_byte;
|
ppc_md.nvram_write_val = direct_nvram_write_byte;
|
||||||
|
ppc_md.nvram_size = ppc32_nvram_size;
|
||||||
} else if (nvram_naddrs == 2) {
|
} else if (nvram_naddrs == 2) {
|
||||||
nvram_addr = ioremap(r1.start, s1);
|
nvram_addr = ioremap(r1.start, s1);
|
||||||
nvram_data = ioremap(r2.start, s2);
|
nvram_data = ioremap(r2.start, s2);
|
||||||
ppc_md.nvram_read_val = indirect_nvram_read_byte;
|
ppc_md.nvram_read_val = indirect_nvram_read_byte;
|
||||||
ppc_md.nvram_write_val = indirect_nvram_write_byte;
|
ppc_md.nvram_write_val = indirect_nvram_write_byte;
|
||||||
|
ppc_md.nvram_size = ppc32_nvram_size;
|
||||||
} else if (nvram_naddrs == 0 && sys_ctrler == SYS_CTRLER_PMU) {
|
} else if (nvram_naddrs == 0 && sys_ctrler == SYS_CTRLER_PMU) {
|
||||||
#ifdef CONFIG_ADB_PMU
|
#ifdef CONFIG_ADB_PMU
|
||||||
nvram_naddrs = -1;
|
nvram_naddrs = -1;
|
||||||
ppc_md.nvram_read_val = pmu_nvram_read_byte;
|
ppc_md.nvram_read_val = pmu_nvram_read_byte;
|
||||||
ppc_md.nvram_write_val = pmu_nvram_write_byte;
|
ppc_md.nvram_write_val = pmu_nvram_write_byte;
|
||||||
|
ppc_md.nvram_size = ppc32_nvram_size;
|
||||||
#endif /* CONFIG_ADB_PMU */
|
#endif /* CONFIG_ADB_PMU */
|
||||||
} else {
|
} else {
|
||||||
printk(KERN_ERR "Incompatible type of NVRAM\n");
|
printk(KERN_ERR "Incompatible type of NVRAM\n");
|
||||||
|
|
Loading…
Reference in New Issue