162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci#include <linux/kernel.h>
362306a36Sopenharmony_ci#include "ubifs.h"
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci/* Normal UBIFS messages */
662306a36Sopenharmony_civoid ubifs_msg(const struct ubifs_info *c, const char *fmt, ...)
762306a36Sopenharmony_ci{
862306a36Sopenharmony_ci	struct va_format vaf;
962306a36Sopenharmony_ci	va_list args;
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci	va_start(args, fmt);
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci	vaf.fmt = fmt;
1462306a36Sopenharmony_ci	vaf.va = &args;
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci	pr_notice("UBIFS (ubi%d:%d): %pV\n",
1762306a36Sopenharmony_ci		  c->vi.ubi_num, c->vi.vol_id, &vaf);
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci	va_end(args);
2062306a36Sopenharmony_ci}								    \
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci/* UBIFS error messages */
2362306a36Sopenharmony_civoid ubifs_err(const struct ubifs_info *c, const char *fmt, ...)
2462306a36Sopenharmony_ci{
2562306a36Sopenharmony_ci	struct va_format vaf;
2662306a36Sopenharmony_ci	va_list args;
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci	va_start(args, fmt);
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci	vaf.fmt = fmt;
3162306a36Sopenharmony_ci	vaf.va = &args;
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci	pr_err("UBIFS error (ubi%d:%d pid %d): %ps: %pV\n",
3462306a36Sopenharmony_ci	       c->vi.ubi_num, c->vi.vol_id, current->pid,
3562306a36Sopenharmony_ci	       __builtin_return_address(0),
3662306a36Sopenharmony_ci	       &vaf);
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci	va_end(args);
3962306a36Sopenharmony_ci}								    \
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci/* UBIFS warning messages */
4262306a36Sopenharmony_civoid ubifs_warn(const struct ubifs_info *c, const char *fmt, ...)
4362306a36Sopenharmony_ci{
4462306a36Sopenharmony_ci	struct va_format vaf;
4562306a36Sopenharmony_ci	va_list args;
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_ci	va_start(args, fmt);
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci	vaf.fmt = fmt;
5062306a36Sopenharmony_ci	vaf.va = &args;
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci	pr_warn("UBIFS warning (ubi%d:%d pid %d): %ps: %pV\n",
5362306a36Sopenharmony_ci		c->vi.ubi_num, c->vi.vol_id, current->pid,
5462306a36Sopenharmony_ci		__builtin_return_address(0),
5562306a36Sopenharmony_ci		&vaf);
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci	va_end(args);
5862306a36Sopenharmony_ci}
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_cistatic char *assert_names[] = {
6162306a36Sopenharmony_ci	[ASSACT_REPORT] = "report",
6262306a36Sopenharmony_ci	[ASSACT_RO] = "read-only",
6362306a36Sopenharmony_ci	[ASSACT_PANIC] = "panic",
6462306a36Sopenharmony_ci};
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_ciconst char *ubifs_assert_action_name(struct ubifs_info *c)
6762306a36Sopenharmony_ci{
6862306a36Sopenharmony_ci	return assert_names[c->assert_action];
6962306a36Sopenharmony_ci}
70