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