|
@@ -18,19 +18,46 @@
|
|
|
* Author: Artem Bityutskiy (Битюцкий Артём)
|
|
|
*/
|
|
|
|
|
|
-/*
|
|
|
- * Here we keep all the UBI debugging stuff which should normally be disabled
|
|
|
- * and compiled-out, but it is extremely helpful when hunting bugs or doing big
|
|
|
- * changes.
|
|
|
- */
|
|
|
-
|
|
|
-#ifdef CONFIG_MTD_UBI_DEBUG
|
|
|
-
|
|
|
#include "ubi.h"
|
|
|
#include <linux/debugfs.h>
|
|
|
#include <linux/uaccess.h>
|
|
|
#include <linux/module.h>
|
|
|
|
|
|
+
|
|
|
+/**
|
|
|
+ * ubi_dump_flash - dump a region of flash.
|
|
|
+ * @ubi: UBI device description object
|
|
|
+ * @pnum: the physical eraseblock number to dump
|
|
|
+ * @offset: the starting offset within the physical eraseblock to dump
|
|
|
+ * @len: the length of the region to dump
|
|
|
+ */
|
|
|
+void ubi_dump_flash(struct ubi_device *ubi, int pnum, int offset, int len)
|
|
|
+{
|
|
|
+ int err;
|
|
|
+ size_t read;
|
|
|
+ void *buf;
|
|
|
+ loff_t addr = (loff_t)pnum * ubi->peb_size + offset;
|
|
|
+
|
|
|
+ buf = vmalloc(len);
|
|
|
+ if (!buf)
|
|
|
+ return;
|
|
|
+ err = mtd_read(ubi->mtd, addr, len, &read, buf);
|
|
|
+ if (err && err != -EUCLEAN) {
|
|
|
+ ubi_err("error %d while reading %d bytes from PEB %d:%d, "
|
|
|
+ "read %zd bytes", err, len, pnum, offset, read);
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
+
|
|
|
+ ubi_msg("dumping %d bytes of data from PEB %d, offset %d",
|
|
|
+ len, pnum, offset);
|
|
|
+ print_hex_dump(KERN_DEBUG, "", DUMP_PREFIX_OFFSET, 32, 1, buf, len, 1);
|
|
|
+out:
|
|
|
+ vfree(buf);
|
|
|
+ return;
|
|
|
+}
|
|
|
+
|
|
|
+#ifdef CONFIG_MTD_UBI_DEBUG
|
|
|
+
|
|
|
/**
|
|
|
* ubi_dbg_dump_ec_hdr - dump an erase counter header.
|
|
|
* @ec_hdr: the erase counter header to dump
|
|
@@ -199,38 +226,6 @@ void ubi_dbg_dump_mkvol_req(const struct ubi_mkvol_req *req)
|
|
|
printk(KERN_DEBUG "\t1st 16 characters of name: %s\n", nm);
|
|
|
}
|
|
|
|
|
|
-/**
|
|
|
- * ubi_dbg_dump_flash - dump a region of flash.
|
|
|
- * @ubi: UBI device description object
|
|
|
- * @pnum: the physical eraseblock number to dump
|
|
|
- * @offset: the starting offset within the physical eraseblock to dump
|
|
|
- * @len: the length of the region to dump
|
|
|
- */
|
|
|
-void ubi_dbg_dump_flash(struct ubi_device *ubi, int pnum, int offset, int len)
|
|
|
-{
|
|
|
- int err;
|
|
|
- size_t read;
|
|
|
- void *buf;
|
|
|
- loff_t addr = (loff_t)pnum * ubi->peb_size + offset;
|
|
|
-
|
|
|
- buf = vmalloc(len);
|
|
|
- if (!buf)
|
|
|
- return;
|
|
|
- err = mtd_read(ubi->mtd, addr, len, &read, buf);
|
|
|
- if (err && err != -EUCLEAN) {
|
|
|
- ubi_err("error %d while reading %d bytes from PEB %d:%d, "
|
|
|
- "read %zd bytes", err, len, pnum, offset, read);
|
|
|
- goto out;
|
|
|
- }
|
|
|
-
|
|
|
- dbg_msg("dumping %d bytes of data from PEB %d, offset %d",
|
|
|
- len, pnum, offset);
|
|
|
- print_hex_dump(KERN_DEBUG, "", DUMP_PREFIX_OFFSET, 32, 1, buf, len, 1);
|
|
|
-out:
|
|
|
- vfree(buf);
|
|
|
- return;
|
|
|
-}
|
|
|
-
|
|
|
/**
|
|
|
* ubi_debugging_init_dev - initialize debugging for an UBI device.
|
|
|
* @ubi: UBI device description object
|