Commit ed59190e authored by Cyril Bur's avatar Cyril Bur Committed by Michael Ellerman

powerpc/powernv: Add interfaces for flash device access

This change adds the OPAL interface definitions to allow Linux to read,
write and erase from system flash devices. We register platform devices
for the flash devices exported by firmware.

We clash with the existing opal_flash_init function, which is really for
the FSP flash update functionality, so we rename that initcall to
opal_flash_update_init().

A future change will add an mtd driver that uses this interface.

Changes from Joel Stanley and Jeremy Kerr.
Signed-off-by: default avatarCyril Bur <cyrilbur@gmail.com>
Signed-off-by: default avatarJeremy Kerr <jk@ozlabs.org>
Signed-off-by: default avatarJoel Stanley <joel@jms.id.au>
Acked-by: default avatarStewart Smith <stewart@linux.vnet.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent d1d91578
...@@ -150,7 +150,10 @@ ...@@ -150,7 +150,10 @@
#define OPAL_IPMI_SEND 107 #define OPAL_IPMI_SEND 107
#define OPAL_IPMI_RECV 108 #define OPAL_IPMI_RECV 108
#define OPAL_I2C_REQUEST 109 #define OPAL_I2C_REQUEST 109
#define OPAL_LAST 109 #define OPAL_FLASH_READ 110
#define OPAL_FLASH_WRITE 111
#define OPAL_FLASH_ERASE 112
#define OPAL_LAST 112
/* Device tree flags */ /* Device tree flags */
......
...@@ -194,6 +194,13 @@ int64_t opal_ipmi_recv(uint64_t interface, struct opal_ipmi_msg *msg, ...@@ -194,6 +194,13 @@ int64_t opal_ipmi_recv(uint64_t interface, struct opal_ipmi_msg *msg,
int64_t opal_i2c_request(uint64_t async_token, uint32_t bus_id, int64_t opal_i2c_request(uint64_t async_token, uint32_t bus_id,
struct opal_i2c_request *oreq); struct opal_i2c_request *oreq);
int64_t opal_flash_read(uint64_t id, uint64_t offset, uint64_t buf,
uint64_t size, uint64_t token);
int64_t opal_flash_write(uint64_t id, uint64_t offset, uint64_t buf,
uint64_t size, uint64_t token);
int64_t opal_flash_erase(uint64_t id, uint64_t offset, uint64_t size,
uint64_t token);
/* Internal functions */ /* Internal functions */
extern int early_init_dt_scan_opal(unsigned long node, const char *uname, extern int early_init_dt_scan_opal(unsigned long node, const char *uname,
int depth, void *data); int depth, void *data);
...@@ -226,7 +233,7 @@ extern int opal_get_sensor_data(u32 sensor_hndl, u32 *sensor_data); ...@@ -226,7 +233,7 @@ extern int opal_get_sensor_data(u32 sensor_hndl, u32 *sensor_data);
struct rtc_time; struct rtc_time;
extern unsigned long opal_get_boot_time(void); extern unsigned long opal_get_boot_time(void);
extern void opal_nvram_init(void); extern void opal_nvram_init(void);
extern void opal_flash_init(void); extern void opal_flash_update_init(void);
extern void opal_flash_term_callback(void); extern void opal_flash_term_callback(void);
extern int opal_elog_init(void); extern int opal_elog_init(void);
extern void opal_platform_dump_init(void); extern void opal_platform_dump_init(void);
......
...@@ -546,7 +546,7 @@ static struct attribute_group image_op_attr_group = { ...@@ -546,7 +546,7 @@ static struct attribute_group image_op_attr_group = {
.attrs = image_op_attrs, .attrs = image_op_attrs,
}; };
void __init opal_flash_init(void) void __init opal_flash_update_init(void)
{ {
int ret; int ret;
......
...@@ -292,3 +292,6 @@ OPAL_CALL(opal_tpo_read, OPAL_READ_TPO); ...@@ -292,3 +292,6 @@ OPAL_CALL(opal_tpo_read, OPAL_READ_TPO);
OPAL_CALL(opal_ipmi_send, OPAL_IPMI_SEND); OPAL_CALL(opal_ipmi_send, OPAL_IPMI_SEND);
OPAL_CALL(opal_ipmi_recv, OPAL_IPMI_RECV); OPAL_CALL(opal_ipmi_recv, OPAL_IPMI_RECV);
OPAL_CALL(opal_i2c_request, OPAL_I2C_REQUEST); OPAL_CALL(opal_i2c_request, OPAL_I2C_REQUEST);
OPAL_CALL(opal_flash_read, OPAL_FLASH_READ);
OPAL_CALL(opal_flash_write, OPAL_FLASH_WRITE);
OPAL_CALL(opal_flash_erase, OPAL_FLASH_ERASE);
...@@ -693,6 +693,15 @@ static void __init opal_dump_region_init(void) ...@@ -693,6 +693,15 @@ static void __init opal_dump_region_init(void)
"rc = %d\n", rc); "rc = %d\n", rc);
} }
static void opal_flash_init(struct device_node *opal_node)
{
struct device_node *np;
for_each_child_of_node(opal_node, np)
if (of_device_is_compatible(np, "ibm,opal-flash"))
of_platform_device_create(np, NULL, NULL);
}
static void opal_ipmi_init(struct device_node *opal_node) static void opal_ipmi_init(struct device_node *opal_node)
{ {
struct device_node *np; struct device_node *np;
...@@ -817,7 +826,7 @@ static int __init opal_init(void) ...@@ -817,7 +826,7 @@ static int __init opal_init(void)
/* Setup error log interface */ /* Setup error log interface */
rc = opal_elog_init(); rc = opal_elog_init();
/* Setup code update interface */ /* Setup code update interface */
opal_flash_init(); opal_flash_update_init();
/* Setup platform dump extract interface */ /* Setup platform dump extract interface */
opal_platform_dump_init(); opal_platform_dump_init();
/* Setup system parameters interface */ /* Setup system parameters interface */
...@@ -829,6 +838,8 @@ static int __init opal_init(void) ...@@ -829,6 +838,8 @@ static int __init opal_init(void)
/* Initialize OPAL IPMI backend */ /* Initialize OPAL IPMI backend */
opal_ipmi_init(opal_node); opal_ipmi_init(opal_node);
opal_flash_init(opal_node);
return 0; return 0;
} }
machine_subsys_initcall(powernv, opal_init); machine_subsys_initcall(powernv, opal_init);
...@@ -867,6 +878,9 @@ void opal_shutdown(void) ...@@ -867,6 +878,9 @@ void opal_shutdown(void)
EXPORT_SYMBOL_GPL(opal_invalid_call); EXPORT_SYMBOL_GPL(opal_invalid_call);
EXPORT_SYMBOL_GPL(opal_ipmi_send); EXPORT_SYMBOL_GPL(opal_ipmi_send);
EXPORT_SYMBOL_GPL(opal_ipmi_recv); EXPORT_SYMBOL_GPL(opal_ipmi_recv);
EXPORT_SYMBOL_GPL(opal_flash_read);
EXPORT_SYMBOL_GPL(opal_flash_write);
EXPORT_SYMBOL_GPL(opal_flash_erase);
/* Convert a region of vmalloc memory to an opal sg list */ /* Convert a region of vmalloc memory to an opal sg list */
struct opal_sg_list *opal_vmalloc_to_sg_list(void *vmalloc_addr, struct opal_sg_list *opal_vmalloc_to_sg_list(void *vmalloc_addr,
......
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