提交 5ca5d4e6 编写于 作者: A Anton Vorontsov 提交者: Greg Kroah-Hartman

pstore/ram: Make ECC size configurable

This is now pretty straightforward: instead of using bool, just pass
an integer. For backwards compatibility ramoops.ecc=1 means 16 bytes
ECC (using 1 byte for ECC isn't much of use anyway).
Suggested-by: NArve Hjønnevåg <arve@android.com>
Signed-off-by: NAnton Vorontsov <anton.vorontsov@linaro.org>
Acked-by: NKees Cook <keescook@chromium.org>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 4a53ffae
...@@ -63,7 +63,9 @@ MODULE_PARM_DESC(dump_oops, ...@@ -63,7 +63,9 @@ MODULE_PARM_DESC(dump_oops,
static int ramoops_ecc; static int ramoops_ecc;
module_param_named(ecc, ramoops_ecc, int, 0600); module_param_named(ecc, ramoops_ecc, int, 0600);
MODULE_PARM_DESC(ramoops_ecc, MODULE_PARM_DESC(ramoops_ecc,
"set to 1 to enable ECC support"); "if non-zero, the option enables ECC support and specifies "
"ECC buffer size in bytes (1 is a special value, means 16 "
"bytes ECC)");
struct ramoops_context { struct ramoops_context {
struct persistent_ram_zone **przs; struct persistent_ram_zone **przs;
...@@ -73,7 +75,7 @@ struct ramoops_context { ...@@ -73,7 +75,7 @@ struct ramoops_context {
size_t record_size; size_t record_size;
size_t console_size; size_t console_size;
int dump_oops; int dump_oops;
bool ecc; int ecc_size;
unsigned int max_dump_cnt; unsigned int max_dump_cnt;
unsigned int dump_write_cnt; unsigned int dump_write_cnt;
unsigned int dump_read_cnt; unsigned int dump_read_cnt;
...@@ -288,7 +290,7 @@ static int ramoops_init_przs(struct device *dev, struct ramoops_context *cxt, ...@@ -288,7 +290,7 @@ static int ramoops_init_przs(struct device *dev, struct ramoops_context *cxt,
for (i = 0; i < cxt->max_dump_cnt; i++) { for (i = 0; i < cxt->max_dump_cnt; i++) {
size_t sz = cxt->record_size; size_t sz = cxt->record_size;
cxt->przs[i] = persistent_ram_new(*paddr, sz, cxt->ecc); cxt->przs[i] = persistent_ram_new(*paddr, sz, cxt->ecc_size);
if (IS_ERR(cxt->przs[i])) { if (IS_ERR(cxt->przs[i])) {
err = PTR_ERR(cxt->przs[i]); err = PTR_ERR(cxt->przs[i]);
dev_err(dev, "failed to request mem region (0x%zx@0x%llx): %d\n", dev_err(dev, "failed to request mem region (0x%zx@0x%llx): %d\n",
...@@ -314,7 +316,7 @@ static int ramoops_init_prz(struct device *dev, struct ramoops_context *cxt, ...@@ -314,7 +316,7 @@ static int ramoops_init_prz(struct device *dev, struct ramoops_context *cxt,
if (*paddr + sz > *paddr + cxt->size) if (*paddr + sz > *paddr + cxt->size)
return -ENOMEM; return -ENOMEM;
*prz = persistent_ram_new(*paddr, sz, cxt->ecc); *prz = persistent_ram_new(*paddr, sz, cxt->ecc_size);
if (IS_ERR(*prz)) { if (IS_ERR(*prz)) {
int err = PTR_ERR(*prz); int err = PTR_ERR(*prz);
...@@ -361,7 +363,7 @@ static int __devinit ramoops_probe(struct platform_device *pdev) ...@@ -361,7 +363,7 @@ static int __devinit ramoops_probe(struct platform_device *pdev)
cxt->record_size = pdata->record_size; cxt->record_size = pdata->record_size;
cxt->console_size = pdata->console_size; cxt->console_size = pdata->console_size;
cxt->dump_oops = pdata->dump_oops; cxt->dump_oops = pdata->dump_oops;
cxt->ecc = pdata->ecc; cxt->ecc_size = pdata->ecc_size;
paddr = cxt->phys_addr; paddr = cxt->phys_addr;
...@@ -411,9 +413,9 @@ static int __devinit ramoops_probe(struct platform_device *pdev) ...@@ -411,9 +413,9 @@ static int __devinit ramoops_probe(struct platform_device *pdev)
record_size = pdata->record_size; record_size = pdata->record_size;
dump_oops = pdata->dump_oops; dump_oops = pdata->dump_oops;
pr_info("attached 0x%lx@0x%llx, ecc: %s\n", pr_info("attached 0x%lx@0x%llx, ecc: %d\n",
cxt->size, (unsigned long long)cxt->phys_addr, cxt->size, (unsigned long long)cxt->phys_addr,
ramoops_ecc ? "on" : "off"); cxt->ecc_size);
return 0; return 0;
...@@ -478,7 +480,11 @@ static void ramoops_register_dummy(void) ...@@ -478,7 +480,11 @@ static void ramoops_register_dummy(void)
dummy_data->record_size = record_size; dummy_data->record_size = record_size;
dummy_data->console_size = ramoops_console_size; dummy_data->console_size = ramoops_console_size;
dummy_data->dump_oops = dump_oops; dummy_data->dump_oops = dump_oops;
dummy_data->ecc = ramoops_ecc; /*
* For backwards compatibility ramoops.ecc=1 means 16 bytes ECC
* (using 1 byte for ECC isn't much of use anyway).
*/
dummy_data->ecc_size = ramoops_ecc == 1 ? 16 : ramoops_ecc;
dummy = platform_device_register_data(NULL, "ramoops", -1, dummy = platform_device_register_data(NULL, "ramoops", -1,
dummy_data, sizeof(struct ramoops_platform_data)); dummy_data, sizeof(struct ramoops_platform_data));
......
...@@ -171,7 +171,8 @@ static void persistent_ram_ecc_old(struct persistent_ram_zone *prz) ...@@ -171,7 +171,8 @@ static void persistent_ram_ecc_old(struct persistent_ram_zone *prz)
} }
} }
static int persistent_ram_init_ecc(struct persistent_ram_zone *prz) static int persistent_ram_init_ecc(struct persistent_ram_zone *prz,
int ecc_size)
{ {
int numerr; int numerr;
struct persistent_ram_buffer *buffer = prz->buffer; struct persistent_ram_buffer *buffer = prz->buffer;
...@@ -184,7 +185,7 @@ static int persistent_ram_init_ecc(struct persistent_ram_zone *prz) ...@@ -184,7 +185,7 @@ static int persistent_ram_init_ecc(struct persistent_ram_zone *prz)
return 0; return 0;
prz->ecc_block_size = 128; prz->ecc_block_size = 128;
prz->ecc_size = 16; prz->ecc_size = ecc_size;
ecc_blocks = DIV_ROUND_UP(prz->buffer_size, prz->ecc_block_size); ecc_blocks = DIV_ROUND_UP(prz->buffer_size, prz->ecc_block_size);
ecc_total = (ecc_blocks + 1) * prz->ecc_size; ecc_total = (ecc_blocks + 1) * prz->ecc_size;
...@@ -390,13 +391,13 @@ static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size, ...@@ -390,13 +391,13 @@ static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size,
} }
static int __devinit persistent_ram_post_init(struct persistent_ram_zone *prz, static int __devinit persistent_ram_post_init(struct persistent_ram_zone *prz,
bool ecc) int ecc_size)
{ {
int ret; int ret;
prz->ecc = ecc; prz->ecc = ecc_size;
ret = persistent_ram_init_ecc(prz); ret = persistent_ram_init_ecc(prz, ecc_size);
if (ret) if (ret)
return ret; return ret;
...@@ -444,7 +445,7 @@ void persistent_ram_free(struct persistent_ram_zone *prz) ...@@ -444,7 +445,7 @@ void persistent_ram_free(struct persistent_ram_zone *prz)
struct persistent_ram_zone * __devinit persistent_ram_new(phys_addr_t start, struct persistent_ram_zone * __devinit persistent_ram_new(phys_addr_t start,
size_t size, size_t size,
bool ecc) int ecc_size)
{ {
struct persistent_ram_zone *prz; struct persistent_ram_zone *prz;
int ret = -ENOMEM; int ret = -ENOMEM;
...@@ -459,7 +460,7 @@ struct persistent_ram_zone * __devinit persistent_ram_new(phys_addr_t start, ...@@ -459,7 +460,7 @@ struct persistent_ram_zone * __devinit persistent_ram_new(phys_addr_t start,
if (ret) if (ret)
goto err; goto err;
ret = persistent_ram_post_init(prz, ecc); ret = persistent_ram_post_init(prz, ecc_size);
if (ret) if (ret)
goto err; goto err;
......
...@@ -48,7 +48,7 @@ struct persistent_ram_zone { ...@@ -48,7 +48,7 @@ struct persistent_ram_zone {
struct persistent_ram_zone * __devinit persistent_ram_new(phys_addr_t start, struct persistent_ram_zone * __devinit persistent_ram_new(phys_addr_t start,
size_t size, size_t size,
bool ecc); int ecc_size);
void persistent_ram_free(struct persistent_ram_zone *prz); void persistent_ram_free(struct persistent_ram_zone *prz);
void persistent_ram_zap(struct persistent_ram_zone *prz); void persistent_ram_zap(struct persistent_ram_zone *prz);
...@@ -74,7 +74,7 @@ struct ramoops_platform_data { ...@@ -74,7 +74,7 @@ struct ramoops_platform_data {
unsigned long record_size; unsigned long record_size;
unsigned long console_size; unsigned long console_size;
int dump_oops; int dump_oops;
bool ecc; int ecc_size;
}; };
#endif #endif
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册