mirror of
https://github.com/FEX-Emu/linux.git
synced 2024-12-20 16:30:53 +00:00
3802243a18
When debugging is disabled, define debugging prints as if (0) printk() to make sure that the compiler still the format string in debugging messages even if debugging is disabled. Signed-off-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com>
232 lines
7.5 KiB
C
232 lines
7.5 KiB
C
/*
|
|
* Copyright (c) International Business Machines Corp., 2006
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
|
|
* the GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*
|
|
* Author: Artem Bityutskiy (Битюцкий Артём)
|
|
*/
|
|
|
|
#ifndef __UBI_DEBUG_H__
|
|
#define __UBI_DEBUG_H__
|
|
|
|
#ifdef CONFIG_MTD_UBI_DEBUG
|
|
#include <linux/random.h>
|
|
|
|
#define dbg_err(fmt, ...) ubi_err(fmt, ##__VA_ARGS__)
|
|
|
|
#define ubi_assert(expr) do { \
|
|
if (unlikely(!(expr))) { \
|
|
printk(KERN_CRIT "UBI assert failed in %s at %u (pid %d)\n", \
|
|
__func__, __LINE__, current->pid); \
|
|
ubi_dbg_dump_stack(); \
|
|
} \
|
|
} while (0)
|
|
|
|
#define dbg_msg(fmt, ...) \
|
|
printk(KERN_DEBUG "UBI DBG (pid %d): %s: " fmt "\n", \
|
|
current->pid, __func__, ##__VA_ARGS__)
|
|
|
|
#define dbg_do_msg(typ, fmt, ...) do { \
|
|
if (ubi_msg_flags & typ) \
|
|
dbg_msg(fmt, ##__VA_ARGS__); \
|
|
} while (0)
|
|
|
|
#define ubi_dbg_dump_stack() dump_stack()
|
|
|
|
struct ubi_ec_hdr;
|
|
struct ubi_vid_hdr;
|
|
struct ubi_volume;
|
|
struct ubi_vtbl_record;
|
|
struct ubi_scan_volume;
|
|
struct ubi_scan_leb;
|
|
struct ubi_mkvol_req;
|
|
|
|
void ubi_dbg_dump_ec_hdr(const struct ubi_ec_hdr *ec_hdr);
|
|
void ubi_dbg_dump_vid_hdr(const struct ubi_vid_hdr *vid_hdr);
|
|
void ubi_dbg_dump_vol_info(const struct ubi_volume *vol);
|
|
void ubi_dbg_dump_vtbl_record(const struct ubi_vtbl_record *r, int idx);
|
|
void ubi_dbg_dump_sv(const struct ubi_scan_volume *sv);
|
|
void ubi_dbg_dump_seb(const struct ubi_scan_leb *seb, int type);
|
|
void ubi_dbg_dump_mkvol_req(const struct ubi_mkvol_req *req);
|
|
void ubi_dbg_dump_flash(struct ubi_device *ubi, int pnum, int offset, int len);
|
|
|
|
extern unsigned int ubi_msg_flags;
|
|
|
|
/*
|
|
* Debugging message type flags (must match msg_type_names in debug.c).
|
|
*
|
|
* UBI_MSG_GEN: general messages
|
|
* UBI_MSG_EBA: journal messages
|
|
* UBI_MSG_WL: mount messages
|
|
* UBI_MSG_IO: commit messages
|
|
* UBI_MSG_BLD: LEB find messages
|
|
*/
|
|
enum {
|
|
UBI_MSG_GEN = 0x1,
|
|
UBI_MSG_EBA = 0x2,
|
|
UBI_MSG_WL = 0x4,
|
|
UBI_MSG_IO = 0x8,
|
|
UBI_MSG_BLD = 0x10,
|
|
};
|
|
|
|
#define ubi_dbg_print_hex_dump(l, ps, pt, r, g, b, len, a) \
|
|
print_hex_dump(l, ps, pt, r, g, b, len, a)
|
|
|
|
/* General debugging messages */
|
|
#define dbg_gen(fmt, ...) dbg_do_msg(UBI_MSG_GEN, fmt, ##__VA_ARGS__)
|
|
|
|
/* Messages from the eraseblock association sub-system */
|
|
#define dbg_eba(fmt, ...) dbg_do_msg(UBI_MSG_EBA, fmt, ##__VA_ARGS__)
|
|
|
|
/* Messages from the wear-leveling sub-system */
|
|
#define dbg_wl(fmt, ...) dbg_do_msg(UBI_MSG_WL, fmt, ##__VA_ARGS__)
|
|
|
|
/* Messages from the input/output sub-system */
|
|
#define dbg_io(fmt, ...) dbg_do_msg(UBI_MSG_IO, fmt, ##__VA_ARGS__)
|
|
|
|
/* Initialization and build messages */
|
|
#define dbg_bld(fmt, ...) dbg_do_msg(UBI_MSG_BLD, fmt, ##__VA_ARGS__)
|
|
|
|
extern unsigned int ubi_chk_flags;
|
|
|
|
/*
|
|
* Debugging check flags.
|
|
*
|
|
* UBI_CHK_GEN: general checks
|
|
* UBI_CHK_IO: check writes and erases
|
|
*/
|
|
enum {
|
|
UBI_CHK_GEN = 0x1,
|
|
UBI_CHK_IO = 0x2,
|
|
};
|
|
|
|
int ubi_dbg_check_all_ff(struct ubi_device *ubi, int pnum, int offset, int len);
|
|
int ubi_dbg_check_write(struct ubi_device *ubi, const void *buf, int pnum,
|
|
int offset, int len);
|
|
|
|
extern unsigned int ubi_tst_flags;
|
|
|
|
/*
|
|
* Special testing flags.
|
|
*
|
|
* UBIFS_TST_DISABLE_BGT: disable the background thread
|
|
* UBI_TST_EMULATE_BITFLIPS: emulate bit-flips
|
|
* UBI_TST_EMULATE_WRITE_FAILURES: emulate write failures
|
|
* UBI_TST_EMULATE_ERASE_FAILURES: emulate erase failures
|
|
*/
|
|
enum {
|
|
UBI_TST_DISABLE_BGT = 0x1,
|
|
UBI_TST_EMULATE_BITFLIPS = 0x2,
|
|
UBI_TST_EMULATE_WRITE_FAILURES = 0x4,
|
|
UBI_TST_EMULATE_ERASE_FAILURES = 0x8,
|
|
};
|
|
|
|
/**
|
|
* ubi_dbg_is_bgt_disabled - if the background thread is disabled.
|
|
*
|
|
* Returns non-zero if the UBI background thread is disabled for testing
|
|
* purposes.
|
|
*/
|
|
static inline int ubi_dbg_is_bgt_disabled(void)
|
|
{
|
|
return ubi_tst_flags & UBI_TST_DISABLE_BGT;
|
|
}
|
|
|
|
/**
|
|
* ubi_dbg_is_bitflip - if it is time to emulate a bit-flip.
|
|
*
|
|
* Returns non-zero if a bit-flip should be emulated, otherwise returns zero.
|
|
*/
|
|
static inline int ubi_dbg_is_bitflip(void)
|
|
{
|
|
if (ubi_tst_flags & UBI_TST_EMULATE_BITFLIPS)
|
|
return !(random32() % 200);
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* ubi_dbg_is_write_failure - if it is time to emulate a write failure.
|
|
*
|
|
* Returns non-zero if a write failure should be emulated, otherwise returns
|
|
* zero.
|
|
*/
|
|
static inline int ubi_dbg_is_write_failure(void)
|
|
{
|
|
if (ubi_tst_flags & UBI_TST_EMULATE_WRITE_FAILURES)
|
|
return !(random32() % 500);
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* ubi_dbg_is_erase_failure - if its time to emulate an erase failure.
|
|
*
|
|
* Returns non-zero if an erase failure should be emulated, otherwise returns
|
|
* zero.
|
|
*/
|
|
static inline int ubi_dbg_is_erase_failure(void)
|
|
{
|
|
if (ubi_tst_flags & UBI_TST_EMULATE_ERASE_FAILURES)
|
|
return !(random32() % 400);
|
|
return 0;
|
|
}
|
|
|
|
#else
|
|
|
|
/* Use "if (0)" to make compiler check arguments even if debugging is off */
|
|
#define ubi_assert(expr) do { \
|
|
if (0) { \
|
|
printk(KERN_CRIT "UBI assert failed in %s at %u (pid %d)\n", \
|
|
__func__, __LINE__, current->pid); \
|
|
} \
|
|
} while (0)
|
|
|
|
#define dbg_err(fmt, ...) do { \
|
|
if (0) \
|
|
ubi_err(fmt, ##__VA_ARGS__); \
|
|
} while (0)
|
|
|
|
#define dbg_msg(fmt, ...) do { \
|
|
if (0) \
|
|
printk(KERN_DEBUG "UBI DBG (pid %d): %s: " fmt "\n", \
|
|
current->pid, __func__, ##__VA_ARGS__); \
|
|
} while (0)
|
|
|
|
#define dbg_gen(fmt, ...) dbg_msg(fmt, ##__VA_ARGS__)
|
|
#define dbg_eba(fmt, ...) dbg_msg(fmt, ##__VA_ARGS__)
|
|
#define dbg_wl(fmt, ...) dbg_msg(fmt, ##__VA_ARGS__)
|
|
#define dbg_io(fmt, ...) dbg_msg(fmt, ##__VA_ARGS__)
|
|
#define dbg_bld(fmt, ...) dbg_msg(fmt, ##__VA_ARGS__)
|
|
|
|
#define ubi_dbg_dump_stack() ({})
|
|
#define ubi_dbg_dump_ec_hdr(ec_hdr) ({})
|
|
#define ubi_dbg_dump_vid_hdr(vid_hdr) ({})
|
|
#define ubi_dbg_dump_vol_info(vol) ({})
|
|
#define ubi_dbg_dump_vtbl_record(r, idx) ({})
|
|
#define ubi_dbg_dump_sv(sv) ({})
|
|
#define ubi_dbg_dump_seb(seb, type) ({})
|
|
#define ubi_dbg_dump_mkvol_req(req) ({})
|
|
#define ubi_dbg_dump_flash(ubi, pnum, offset, len) ({})
|
|
#define ubi_dbg_print_hex_dump(l, ps, pt, r, g, b, len, a) ({})
|
|
|
|
#define ubi_dbg_is_bgt_disabled() 0
|
|
#define ubi_dbg_is_bitflip() 0
|
|
#define ubi_dbg_is_write_failure() 0
|
|
#define ubi_dbg_is_erase_failure() 0
|
|
#define ubi_dbg_check_all_ff(ubi, pnum, offset, len) 0
|
|
#define ubi_dbg_check_write(ubi, buf, pnum, offset, len) 0
|
|
|
|
#endif /* !CONFIG_MTD_UBI_DEBUG */
|
|
#endif /* !__UBI_DEBUG_H__ */
|