Commit 78989f0a authored by Hari Bathini's avatar Hari Bathini Committed by Michael Ellerman

powerpc/nvram: Move generic code for nvram and pstore

With minor checks, we can move most of the code for nvram
under pseries to a common place to be re-used by other
powerpc platforms like powernv. This patch moves such
common code to arch/powerpc/kernel/nvram_64.c file.
Signed-off-by: default avatarHari Bathini <hbathini@linux.vnet.ibm.com>
[mpe: Move select of ZLIB_DEFLATE to PPC64 to fix the build]
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent 3af229f2
...@@ -9,12 +9,43 @@ ...@@ -9,12 +9,43 @@
#ifndef _ASM_POWERPC_NVRAM_H #ifndef _ASM_POWERPC_NVRAM_H
#define _ASM_POWERPC_NVRAM_H #define _ASM_POWERPC_NVRAM_H
#include <linux/types.h>
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/list.h> #include <linux/list.h>
#include <uapi/asm/nvram.h> #include <uapi/asm/nvram.h>
/*
* Set oops header version to distinguish between old and new format header.
* lnx,oops-log partition max size is 4000, header version > 4000 will
* help in identifying new header.
*/
#define OOPS_HDR_VERSION 5000
struct err_log_info {
__be32 error_type;
__be32 seq_num;
};
struct nvram_os_partition {
const char *name;
int req_size; /* desired size, in bytes */
int min_size; /* minimum acceptable size (0 means req_size) */
long size; /* size of data portion (excluding err_log_info) */
long index; /* offset of data portion of partition */
bool os_partition; /* partition initialized by OS, not FW */
};
struct oops_log_info {
__be16 version;
__be16 report_length;
__be64 timestamp;
} __attribute__((packed));
extern struct nvram_os_partition oops_log_partition;
#ifdef CONFIG_PPC_PSERIES #ifdef CONFIG_PPC_PSERIES
extern struct nvram_os_partition rtas_log_partition;
extern int nvram_write_error_log(char * buff, int length, extern int nvram_write_error_log(char * buff, int length,
unsigned int err_type, unsigned int err_seq); unsigned int err_type, unsigned int err_seq);
extern int nvram_read_error_log(char * buff, int length, extern int nvram_read_error_log(char * buff, int length,
...@@ -50,6 +81,23 @@ extern void pmac_xpram_write(int xpaddr, u8 data); ...@@ -50,6 +81,23 @@ extern void pmac_xpram_write(int xpaddr, u8 data);
/* Synchronize NVRAM */ /* Synchronize NVRAM */
extern void nvram_sync(void); extern void nvram_sync(void);
/* Initialize NVRAM OS partition */
extern int __init nvram_init_os_partition(struct nvram_os_partition *part);
/* Initialize NVRAM oops partition */
extern void __init nvram_init_oops_partition(int rtas_partition_exists);
/* Read a NVRAM partition */
extern int nvram_read_partition(struct nvram_os_partition *part, char *buff,
int length, unsigned int *err_type,
unsigned int *error_log_cnt);
/* Write to NVRAM OS partition */
extern int nvram_write_os_partition(struct nvram_os_partition *part,
char *buff, int length,
unsigned int err_type,
unsigned int error_log_cnt);
/* Determine NVRAM size */ /* Determine NVRAM size */
extern ssize_t nvram_get_size(void); extern ssize_t nvram_get_size(void);
......
...@@ -343,8 +343,12 @@ extern int early_init_dt_scan_rtas(unsigned long node, ...@@ -343,8 +343,12 @@ extern int early_init_dt_scan_rtas(unsigned long node,
extern void pSeries_log_error(char *buf, unsigned int err_type, int fatal); extern void pSeries_log_error(char *buf, unsigned int err_type, int fatal);
#ifdef CONFIG_PPC_PSERIES #ifdef CONFIG_PPC_PSERIES
extern unsigned long last_rtas_event;
extern int clobbering_unread_rtas_event(void);
extern int pseries_devicetree_update(s32 scope); extern int pseries_devicetree_update(s32 scope);
extern void post_mobility_fixup(void); extern void post_mobility_fixup(void);
#else
static inline int clobbering_unread_rtas_event(void) { return 0; }
#endif #endif
#ifdef CONFIG_PPC_RTAS_DAEMON #ifdef CONFIG_PPC_RTAS_DAEMON
......
This diff is collapsed.
...@@ -2,6 +2,7 @@ config PPC64 ...@@ -2,6 +2,7 @@ config PPC64
bool "64-bit kernel" bool "64-bit kernel"
default n default n
select HAVE_VIRT_CPU_ACCOUNTING select HAVE_VIRT_CPU_ACCOUNTING
select ZLIB_DEFLATE
help help
This option selects whether a 32-bit or a 64-bit kernel This option selects whether a 32-bit or a 64-bit kernel
will be built. will be built.
......
...@@ -16,7 +16,6 @@ config PPC_PSERIES ...@@ -16,7 +16,6 @@ config PPC_PSERIES
select PPC_UDBG_16550 select PPC_UDBG_16550
select PPC_NATIVE select PPC_NATIVE
select PPC_PCI_CHOICE if EXPERT select PPC_PCI_CHOICE if EXPERT
select ZLIB_DEFLATE
select PPC_DOORBELL select PPC_DOORBELL
select HAVE_CONTEXT_TRACKING select HAVE_CONTEXT_TRACKING
select HOTPLUG_CPU if SMP select HOTPLUG_CPU if SMP
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment