Re: [PATCH 4/9] pstore: Allow the user to explicitly choose a backend

From: Konrad Rzeszutek Wilk
Date: Wed Jul 20 2011 - 09:29:11 EST


On Mon, Jul 18, 2011 at 04:30:28PM -0400, Matthew Garrett wrote:
> pstore only allows one backend to be registered at present, but the
> system may provide several. Add a parameter to allow the user to choose
> which backend will be used rather than just relying on load order.
>
> Signed-off-by: Matthew Garrett <mjg@xxxxxxxxxx>
> ---
> Documentation/ABI/testing/pstore | 5 +++++
> Documentation/kernel-parameters.txt | 2 ++
> fs/pstore/platform.c | 11 +++++++++++
> 3 files changed, 18 insertions(+), 0 deletions(-)
>
> diff --git a/Documentation/ABI/testing/pstore b/Documentation/ABI/testing/pstore
> index ddf451e..1aa4035 100644
> --- a/Documentation/ABI/testing/pstore
> +++ b/Documentation/ABI/testing/pstore
> @@ -39,3 +39,8 @@ Description: Generic interface to platform dependent persistent storage.
> multiple) files based on the record size of the underlying
> persistent storage until at least this amount is reached.
> Default is 10 Kbytes.
> +
> + Pstore only supports one backend at a time. If multiple
> + backends are available, the preferred backend may be
> + set by passing the pstore.backend= argument to the kernel
> + or writing to /sys/module/pstore/parameters/backend .
> \ No newline at end of file
> diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt
> index ede3209..abafa88 100644
> --- a/Documentation/kernel-parameters.txt
> +++ b/Documentation/kernel-parameters.txt
> @@ -2156,6 +2156,8 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
> [HW,MOUSE] Controls Logitech smartscroll autorepeat.
> 0 = disabled, 1 = enabled (default).
>
> + pstore.backend= Specify the name of the pstore backend to use
> +
> pt. [PARIDE]
> See Documentation/blockdev/paride.txt.
>
> diff --git a/fs/pstore/platform.c b/fs/pstore/platform.c
> index 49ff1de..94200d6 100644
> --- a/fs/pstore/platform.c
> +++ b/fs/pstore/platform.c
> @@ -37,6 +37,8 @@
> static DEFINE_SPINLOCK(pstore_lock);
> static struct pstore_info *psinfo;
>
> +static char *backend;
> +
> /* How much of the console log to snapshot */
> static unsigned long kmsg_bytes = 10240;
>
> @@ -131,6 +133,12 @@ int pstore_register(struct pstore_info *psi)
> spin_unlock(&pstore_lock);
> return -EBUSY;
> }
> +
> + if (backend && strcmp(backend, psi->name)) {

Is there a limit of how big the backend name can be? If so would it
make sense to use to strncmp?

> + spin_unlock(&pstore_lock);
> + return -EBUSY;
> + }
> +
> psinfo = psi;
> spin_unlock(&pstore_lock);
>
> @@ -208,3 +216,6 @@ int pstore_write(enum pstore_type_id type, char *buf, size_t size)
> return 0;
> }
> EXPORT_SYMBOL_GPL(pstore_write);
> +
> +module_param(backend, charp, 0644);
> +MODULE_PARM_DESC(backend, "Pstore backend to use");
> --
> 1.7.6
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/