xref: /rk3399_rockchip-uboot/fs/ubifs/debug.c (revision 9eefe2a2b37a838558e3d213a9f5519503d0c180)
1*9eefe2a2SStefan Roese /*
2*9eefe2a2SStefan Roese  * This file is part of UBIFS.
3*9eefe2a2SStefan Roese  *
4*9eefe2a2SStefan Roese  * Copyright (C) 2006-2008 Nokia Corporation
5*9eefe2a2SStefan Roese  *
6*9eefe2a2SStefan Roese  * This program is free software; you can redistribute it and/or modify it
7*9eefe2a2SStefan Roese  * under the terms of the GNU General Public License version 2 as published by
8*9eefe2a2SStefan Roese  * the Free Software Foundation.
9*9eefe2a2SStefan Roese  *
10*9eefe2a2SStefan Roese  * This program is distributed in the hope that it will be useful, but WITHOUT
11*9eefe2a2SStefan Roese  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12*9eefe2a2SStefan Roese  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
13*9eefe2a2SStefan Roese  * more details.
14*9eefe2a2SStefan Roese  *
15*9eefe2a2SStefan Roese  * You should have received a copy of the GNU General Public License along with
16*9eefe2a2SStefan Roese  * this program; if not, write to the Free Software Foundation, Inc., 51
17*9eefe2a2SStefan Roese  * Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18*9eefe2a2SStefan Roese  *
19*9eefe2a2SStefan Roese  * Authors: Artem Bityutskiy (Битюцкий Артём)
20*9eefe2a2SStefan Roese  *          Adrian Hunter
21*9eefe2a2SStefan Roese  */
22*9eefe2a2SStefan Roese 
23*9eefe2a2SStefan Roese /*
24*9eefe2a2SStefan Roese  * This file implements most of the debugging stuff which is compiled in only
25*9eefe2a2SStefan Roese  * when it is enabled. But some debugging check functions are implemented in
26*9eefe2a2SStefan Roese  * corresponding subsystem, just because they are closely related and utilize
27*9eefe2a2SStefan Roese  * various local functions of those subsystems.
28*9eefe2a2SStefan Roese  */
29*9eefe2a2SStefan Roese 
30*9eefe2a2SStefan Roese #define UBIFS_DBG_PRESERVE_UBI
31*9eefe2a2SStefan Roese 
32*9eefe2a2SStefan Roese #include "ubifs.h"
33*9eefe2a2SStefan Roese 
34*9eefe2a2SStefan Roese #ifdef CONFIG_UBIFS_FS_DEBUG
35*9eefe2a2SStefan Roese 
36*9eefe2a2SStefan Roese DEFINE_SPINLOCK(dbg_lock);
37*9eefe2a2SStefan Roese 
38*9eefe2a2SStefan Roese static char dbg_key_buf0[128];
39*9eefe2a2SStefan Roese static char dbg_key_buf1[128];
40*9eefe2a2SStefan Roese 
41*9eefe2a2SStefan Roese unsigned int ubifs_msg_flags = UBIFS_MSG_FLAGS_DEFAULT;
42*9eefe2a2SStefan Roese unsigned int ubifs_chk_flags = UBIFS_CHK_FLAGS_DEFAULT;
43*9eefe2a2SStefan Roese unsigned int ubifs_tst_flags;
44*9eefe2a2SStefan Roese 
45*9eefe2a2SStefan Roese module_param_named(debug_msgs, ubifs_msg_flags, uint, S_IRUGO | S_IWUSR);
46*9eefe2a2SStefan Roese module_param_named(debug_chks, ubifs_chk_flags, uint, S_IRUGO | S_IWUSR);
47*9eefe2a2SStefan Roese module_param_named(debug_tsts, ubifs_tst_flags, uint, S_IRUGO | S_IWUSR);
48*9eefe2a2SStefan Roese 
49*9eefe2a2SStefan Roese MODULE_PARM_DESC(debug_msgs, "Debug message type flags");
50*9eefe2a2SStefan Roese MODULE_PARM_DESC(debug_chks, "Debug check flags");
51*9eefe2a2SStefan Roese MODULE_PARM_DESC(debug_tsts, "Debug special test flags");
52*9eefe2a2SStefan Roese 
53*9eefe2a2SStefan Roese static const char *get_key_type(int type)
54*9eefe2a2SStefan Roese {
55*9eefe2a2SStefan Roese 	switch (type) {
56*9eefe2a2SStefan Roese 	case UBIFS_INO_KEY:
57*9eefe2a2SStefan Roese 		return "inode";
58*9eefe2a2SStefan Roese 	case UBIFS_DENT_KEY:
59*9eefe2a2SStefan Roese 		return "direntry";
60*9eefe2a2SStefan Roese 	case UBIFS_XENT_KEY:
61*9eefe2a2SStefan Roese 		return "xentry";
62*9eefe2a2SStefan Roese 	case UBIFS_DATA_KEY:
63*9eefe2a2SStefan Roese 		return "data";
64*9eefe2a2SStefan Roese 	case UBIFS_TRUN_KEY:
65*9eefe2a2SStefan Roese 		return "truncate";
66*9eefe2a2SStefan Roese 	default:
67*9eefe2a2SStefan Roese 		return "unknown/invalid key";
68*9eefe2a2SStefan Roese 	}
69*9eefe2a2SStefan Roese }
70*9eefe2a2SStefan Roese 
71*9eefe2a2SStefan Roese static void sprintf_key(const struct ubifs_info *c, const union ubifs_key *key,
72*9eefe2a2SStefan Roese 			char *buffer)
73*9eefe2a2SStefan Roese {
74*9eefe2a2SStefan Roese 	char *p = buffer;
75*9eefe2a2SStefan Roese 	int type = key_type(c, key);
76*9eefe2a2SStefan Roese 
77*9eefe2a2SStefan Roese 	if (c->key_fmt == UBIFS_SIMPLE_KEY_FMT) {
78*9eefe2a2SStefan Roese 		switch (type) {
79*9eefe2a2SStefan Roese 		case UBIFS_INO_KEY:
80*9eefe2a2SStefan Roese 			sprintf(p, "(%lu, %s)", (unsigned long)key_inum(c, key),
81*9eefe2a2SStefan Roese 			       get_key_type(type));
82*9eefe2a2SStefan Roese 			break;
83*9eefe2a2SStefan Roese 		case UBIFS_DENT_KEY:
84*9eefe2a2SStefan Roese 		case UBIFS_XENT_KEY:
85*9eefe2a2SStefan Roese 			sprintf(p, "(%lu, %s, %#08x)",
86*9eefe2a2SStefan Roese 				(unsigned long)key_inum(c, key),
87*9eefe2a2SStefan Roese 				get_key_type(type), key_hash(c, key));
88*9eefe2a2SStefan Roese 			break;
89*9eefe2a2SStefan Roese 		case UBIFS_DATA_KEY:
90*9eefe2a2SStefan Roese 			sprintf(p, "(%lu, %s, %u)",
91*9eefe2a2SStefan Roese 				(unsigned long)key_inum(c, key),
92*9eefe2a2SStefan Roese 				get_key_type(type), key_block(c, key));
93*9eefe2a2SStefan Roese 			break;
94*9eefe2a2SStefan Roese 		case UBIFS_TRUN_KEY:
95*9eefe2a2SStefan Roese 			sprintf(p, "(%lu, %s)",
96*9eefe2a2SStefan Roese 				(unsigned long)key_inum(c, key),
97*9eefe2a2SStefan Roese 				get_key_type(type));
98*9eefe2a2SStefan Roese 			break;
99*9eefe2a2SStefan Roese 		default:
100*9eefe2a2SStefan Roese 			sprintf(p, "(bad key type: %#08x, %#08x)",
101*9eefe2a2SStefan Roese 				key->u32[0], key->u32[1]);
102*9eefe2a2SStefan Roese 		}
103*9eefe2a2SStefan Roese 	} else
104*9eefe2a2SStefan Roese 		sprintf(p, "bad key format %d", c->key_fmt);
105*9eefe2a2SStefan Roese }
106*9eefe2a2SStefan Roese 
107*9eefe2a2SStefan Roese const char *dbg_key_str0(const struct ubifs_info *c, const union ubifs_key *key)
108*9eefe2a2SStefan Roese {
109*9eefe2a2SStefan Roese 	/* dbg_lock must be held */
110*9eefe2a2SStefan Roese 	sprintf_key(c, key, dbg_key_buf0);
111*9eefe2a2SStefan Roese 	return dbg_key_buf0;
112*9eefe2a2SStefan Roese }
113*9eefe2a2SStefan Roese 
114*9eefe2a2SStefan Roese const char *dbg_key_str1(const struct ubifs_info *c, const union ubifs_key *key)
115*9eefe2a2SStefan Roese {
116*9eefe2a2SStefan Roese 	/* dbg_lock must be held */
117*9eefe2a2SStefan Roese 	sprintf_key(c, key, dbg_key_buf1);
118*9eefe2a2SStefan Roese 	return dbg_key_buf1;
119*9eefe2a2SStefan Roese }
120*9eefe2a2SStefan Roese 
121*9eefe2a2SStefan Roese /**
122*9eefe2a2SStefan Roese  * ubifs_debugging_init - initialize UBIFS debugging.
123*9eefe2a2SStefan Roese  * @c: UBIFS file-system description object
124*9eefe2a2SStefan Roese  *
125*9eefe2a2SStefan Roese  * This function initializes debugging-related data for the file system.
126*9eefe2a2SStefan Roese  * Returns zero in case of success and a negative error code in case of
127*9eefe2a2SStefan Roese  * failure.
128*9eefe2a2SStefan Roese  */
129*9eefe2a2SStefan Roese int ubifs_debugging_init(struct ubifs_info *c)
130*9eefe2a2SStefan Roese {
131*9eefe2a2SStefan Roese 	c->dbg = kzalloc(sizeof(struct ubifs_debug_info), GFP_KERNEL);
132*9eefe2a2SStefan Roese 	if (!c->dbg)
133*9eefe2a2SStefan Roese 		return -ENOMEM;
134*9eefe2a2SStefan Roese 
135*9eefe2a2SStefan Roese 	c->dbg->buf = vmalloc(c->leb_size);
136*9eefe2a2SStefan Roese 	if (!c->dbg->buf)
137*9eefe2a2SStefan Roese 		goto out;
138*9eefe2a2SStefan Roese 
139*9eefe2a2SStefan Roese 	return 0;
140*9eefe2a2SStefan Roese 
141*9eefe2a2SStefan Roese out:
142*9eefe2a2SStefan Roese 	kfree(c->dbg);
143*9eefe2a2SStefan Roese 	return -ENOMEM;
144*9eefe2a2SStefan Roese }
145*9eefe2a2SStefan Roese 
146*9eefe2a2SStefan Roese /**
147*9eefe2a2SStefan Roese  * ubifs_debugging_exit - free debugging data.
148*9eefe2a2SStefan Roese  * @c: UBIFS file-system description object
149*9eefe2a2SStefan Roese  */
150*9eefe2a2SStefan Roese void ubifs_debugging_exit(struct ubifs_info *c)
151*9eefe2a2SStefan Roese {
152*9eefe2a2SStefan Roese 	vfree(c->dbg->buf);
153*9eefe2a2SStefan Roese 	kfree(c->dbg);
154*9eefe2a2SStefan Roese }
155*9eefe2a2SStefan Roese 
156*9eefe2a2SStefan Roese #endif /* CONFIG_UBIFS_FS_DEBUG */
157