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