aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/mediatek/files-5.10/drivers/mtd/mtk-snand/mtk-snand-os.c
blob: 0c3ffec8b4c8914a9d74837238d3199ddf342de5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// SPDX-License-Identifier: GPL-2.0
/*
 * Copyright (C) 2020 MediaTek Inc. All Rights Reserved.
 *
 * Author: Weijie Gao <weijie.gao@mediatek.com>
 */

#include "mtk-snand-def.h"

int mtk_snand_log(struct mtk_snand_plat_dev *pdev,
		  enum mtk_snand_log_category cat, const char *fmt, ...)
{
	const char *catname = "";
	va_list ap;
	char *msg;

	switch (cat) {
	case SNAND_LOG_NFI:
		catname = "NFI";
		break;
	case SNAND_LOG_SNFI:
		catname = "SNFI";
		break;
	case SNAND_LOG_ECC:
		catname = "ECC";
		break;
	default:
		break;
	}

	va_start(ap, fmt);
	msg = kvasprintf(GFP_KERNEL, fmt, ap);
	va_end(ap);

	if (!msg) {
		dev_warn(pdev->dev, "unable to print log\n");
		return -1;
	}

	if (*catname)
		dev_warn(pdev->dev, "%s: %s", catname, msg);
	else
		dev_warn(pdev->dev, "%s", msg);

	kfree(msg);

	return 0;
}