mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-30 08:31:03 +00:00
tools: imls: Remove a broken and unused tool.
It looks like tools/imls/Makefile is invoked from nowhere. And also it is broken. Signed-off-by: Masahiro Yamada <yamada.m@jp.panasonic.com>
This commit is contained in:
parent
9dfdcdfed4
commit
cfe19f917a
3 changed files with 0 additions and 381 deletions
|
@ -1,84 +0,0 @@
|
|||
#
|
||||
# (C) Copyright 2009 Marco Stornelli <marco.stornelli@gmail.com>
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
include $(TOPDIR)/config.mk
|
||||
|
||||
# Generated executable files
|
||||
BIN_FILES-y += imls
|
||||
|
||||
# Source files which exist outside the tools/imls directory
|
||||
EXT_OBJ_FILES-y += lib/crc32.o
|
||||
EXT_OBJ_FILES-y += lib/md5.o
|
||||
EXT_OBJ_FILES-y += lib/sha1.o
|
||||
EXT_OBJ_FILES-y += common/image.o
|
||||
|
||||
# Source files located in the tools/imls directory
|
||||
OBJ_FILES-y += imls.o
|
||||
|
||||
# Flattened device tree objects
|
||||
LIBFDT_OBJ_FILES-y += fdt.o
|
||||
LIBFDT_OBJ_FILES-y += fdt_ro.o
|
||||
LIBFDT_OBJ_FILES-y += fdt_rw.o
|
||||
LIBFDT_OBJ_FILES-y += fdt_strerror.o
|
||||
LIBFDT_OBJ_FILES-y += fdt_wip.o
|
||||
|
||||
# now $(obj) is defined
|
||||
SRCS += $(addprefix $(SRCTREE)/,$(EXT_OBJ_FILES-y:.o=.c))
|
||||
SRCS += $(addprefix $(SRCTREE)/tools/,$(OBJ_FILES-y:.o=.c))
|
||||
SRCS += $(addprefix $(SRCTREE)/lib/libfdt/,$(LIBFDT_OBJ_FILES-y:.o=.c))
|
||||
BINS := $(addprefix $(obj),$(sort $(BIN_FILES-y)))
|
||||
LIBFDT_OBJS := $(addprefix $(obj),$(LIBFDT_OBJ_FILES-y))
|
||||
|
||||
#
|
||||
# Compile for a hosted environment on the target
|
||||
# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
|
||||
#
|
||||
HOSTCPPFLAGS = -idirafter $(SRCTREE)/include \
|
||||
-idirafter $(SRCTREE)/arch/$(ARCH)/include \
|
||||
-idirafter $(OBJTREE)/include \
|
||||
-I $(SRCTREE)/lib/libfdt \
|
||||
-I $(SRCTREE)/tools \
|
||||
-DUSE_HOSTCC -D__KERNEL_STRICT_NAMES
|
||||
|
||||
ifeq ($(MTD_VERSION),old)
|
||||
HOSTCPPFLAGS += -DMTD_OLD
|
||||
endif
|
||||
|
||||
all: $(BINS)
|
||||
|
||||
$(obj)imls: $(obj)imls.o $(obj)crc32.o $(obj)image.o $(obj)md5.o \
|
||||
$(obj)sha1.o $(LIBFDT_OBJS)
|
||||
$(CC) $(HOSTCFLAGS) $(HOSTLDFLAGS) -o $@ $^
|
||||
$(STRIP) $@
|
||||
|
||||
# Some files complain if compiled with -pedantic, use HOSTCFLAGS_NOPED
|
||||
$(obj)image.o: $(SRCTREE)/common/image.c
|
||||
$(CC) -g $(HOSTCFLAGS_NOPED) -c -o $@ $<
|
||||
|
||||
$(obj)imls.o: $(SRCTREE)/tools/imls/imls.c
|
||||
$(CC) -g $(HOSTCFLAGS_NOPED) -c -o $@ $<
|
||||
|
||||
# Some of the tool objects need to be accessed from outside the tools/imls directory
|
||||
$(obj)%.o: $(SRCTREE)/common/%.c
|
||||
$(CC) -g $(HOSTCFLAGS_NOPED) -c -o $@ $<
|
||||
|
||||
$(obj)%.o: $(SRCTREE)/lib/%.c
|
||||
$(CC) -g $(HOSTCFLAGS) -c -o $@ $<
|
||||
|
||||
$(obj)%.o: $(SRCTREE)/lib/libfdt/%.c
|
||||
$(CC) -g $(HOSTCFLAGS_NOPED) -c -o $@ $<
|
||||
|
||||
clean:
|
||||
rm -rf *.o imls
|
||||
|
||||
#########################################################################
|
||||
|
||||
# defines $(obj).depend target
|
||||
include $(SRCTREE)/rules.mk
|
||||
|
||||
sinclude $(obj).depend
|
||||
|
||||
#########################################################################
|
|
@ -1,41 +0,0 @@
|
|||
#
|
||||
# (C) Copyright 2009 Marco Stornelli <marco.stornelli@gmail.com>
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
IMLS
|
||||
-------------
|
||||
|
||||
imls is an implementation of a Linux command line tool to access
|
||||
to raw flash partitions and list images made with mkimage command.
|
||||
|
||||
For building against older versions of the MTD headers (meaning before
|
||||
v2.6.8-rc1) it is required to pass the argument "MTD_VERSION=old" to
|
||||
make.
|
||||
|
||||
Usage examples
|
||||
--------------
|
||||
|
||||
1) Flash with sectors of 128KiB and 32 sectors:
|
||||
|
||||
> imls -c 32 -s 131072 /dev/mtd0
|
||||
Searching...
|
||||
Image Name: foo
|
||||
Created: Fri Apr 10 18:11:30 2009
|
||||
Image Type: Intel x86 Linux Standalone Program (uncompressed)
|
||||
Data Size: 10716 Bytes = 10.46 kB = 0.01 MB
|
||||
Load Address: 00000000
|
||||
Entry Point: 00000000
|
||||
|
||||
2) Flash with sectors of 64KiB and 128 sectors and with a search offset of one
|
||||
sector:
|
||||
|
||||
> imls -o 1 -c 128 -s 65536 /dev/mtd0
|
||||
Searching...
|
||||
Image Name: foo
|
||||
Created: Fri Apr 10 18:11:30 2009
|
||||
Image Type: Intel x86 Linux Standalone Program (uncompressed)
|
||||
Data Size: 10716 Bytes = 10.46 kB = 0.01 MB
|
||||
Load Address: 00000000
|
||||
Entry Point: 00000000
|
|
@ -1,256 +0,0 @@
|
|||
/*
|
||||
* (C) Copyright 2009 Marco Stornelli
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <stddef.h>
|
||||
#include <string.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/ioctl.h>
|
||||
#include <sys/stat.h>
|
||||
#include <unistd.h>
|
||||
#include <asm/page.h>
|
||||
|
||||
#ifdef MTD_OLD
|
||||
#include <stdint.h>
|
||||
#include <linux/mtd/mtd.h>
|
||||
#else
|
||||
#define __user /* nothing */
|
||||
#include <mtd/mtd-user.h>
|
||||
#endif
|
||||
|
||||
#include <sha1.h>
|
||||
#include <libfdt.h>
|
||||
#include <fdt_support.h>
|
||||
#include <image.h>
|
||||
|
||||
#define MIN(a, b) (((a) < (b)) ? (a) : (b))
|
||||
|
||||
extern unsigned long crc32(unsigned long crc, const char *buf, unsigned int len);
|
||||
static void usage(void);
|
||||
static int image_verify_header(char *ptr, int fd);
|
||||
static int flash_bad_block(int fd, uint8_t mtd_type, loff_t start);
|
||||
|
||||
char *cmdname;
|
||||
char *devicefile;
|
||||
|
||||
unsigned int sectorcount = 0;
|
||||
int sflag = 0;
|
||||
unsigned int sectoroffset = 0;
|
||||
unsigned int sectorsize = 0;
|
||||
int cflag = 0;
|
||||
|
||||
int main (int argc, char **argv)
|
||||
{
|
||||
int fd = -1, err = 0, readbyte = 0, j;
|
||||
struct mtd_info_user mtdinfo;
|
||||
char buf[sizeof(image_header_t)];
|
||||
int found = 0;
|
||||
|
||||
cmdname = *argv;
|
||||
|
||||
while (--argc > 0 && **++argv == '-') {
|
||||
while (*++*argv) {
|
||||
switch (**argv) {
|
||||
case 'c':
|
||||
if (--argc <= 0)
|
||||
usage ();
|
||||
sectorcount = (unsigned int)atoi(*++argv);
|
||||
cflag = 1;
|
||||
goto NXTARG;
|
||||
case 'o':
|
||||
if (--argc <= 0)
|
||||
usage ();
|
||||
sectoroffset = (unsigned int)atoi(*++argv);
|
||||
goto NXTARG;
|
||||
|
||||
case 's':
|
||||
if (--argc <= 0)
|
||||
usage ();
|
||||
sectorsize = (unsigned int)atoi(*++argv);
|
||||
sflag = 1;
|
||||
goto NXTARG;
|
||||
default:
|
||||
usage ();
|
||||
}
|
||||
}
|
||||
NXTARG: ;
|
||||
}
|
||||
|
||||
if (argc != 1 || cflag == 0 || sflag == 0)
|
||||
usage();
|
||||
|
||||
devicefile = *argv;
|
||||
|
||||
fd = open(devicefile, O_RDONLY);
|
||||
if (fd < 0) {
|
||||
fprintf (stderr, "%s: Can't open %s: %s\n",
|
||||
cmdname, devicefile, strerror(errno));
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
err = ioctl(fd, MEMGETINFO, &mtdinfo);
|
||||
if (err < 0) {
|
||||
fprintf(stderr, "%s: Cannot get MTD information: %s\n",cmdname,
|
||||
strerror(errno));
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (mtdinfo.type != MTD_NORFLASH && mtdinfo.type != MTD_NANDFLASH) {
|
||||
fprintf(stderr, "%s: Unsupported flash type %u\n",
|
||||
cmdname, mtdinfo.type);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (sectorsize * sectorcount != mtdinfo.size) {
|
||||
fprintf(stderr, "%s: Partition size (%d) incompatible with "
|
||||
"sector size and count\n", cmdname, mtdinfo.size);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (sectorsize * sectoroffset >= mtdinfo.size) {
|
||||
fprintf(stderr, "%s: Partition size (%d) incompatible with "
|
||||
"sector offset given\n", cmdname, mtdinfo.size);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (sectoroffset > sectorcount - 1) {
|
||||
fprintf(stderr, "%s: Sector offset cannot be grater than "
|
||||
"sector count minus one\n", cmdname);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
printf("Searching....\n");
|
||||
|
||||
for (j = sectoroffset; j < sectorcount; ++j) {
|
||||
|
||||
if (lseek(fd, j*sectorsize, SEEK_SET) != j*sectorsize) {
|
||||
fprintf(stderr, "%s: lseek failure: %s\n",
|
||||
cmdname, strerror(errno));
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
err = flash_bad_block(fd, mtdinfo.type, j*sectorsize);
|
||||
if (err < 0)
|
||||
exit(EXIT_FAILURE);
|
||||
if (err)
|
||||
continue; /* Skip and jump to next */
|
||||
|
||||
readbyte = read(fd, buf, sizeof(image_header_t));
|
||||
if (readbyte != sizeof(image_header_t)) {
|
||||
fprintf(stderr, "%s: Can't read from device: %s\n",
|
||||
cmdname, strerror(errno));
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (fdt_check_header(buf)) {
|
||||
/* old-style image */
|
||||
if (image_verify_header(buf, fd)) {
|
||||
found = 1;
|
||||
image_print_contents((image_header_t *)buf);
|
||||
}
|
||||
} else {
|
||||
/* FIT image */
|
||||
fit_print_contents(buf);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
close(fd);
|
||||
|
||||
if(!found)
|
||||
printf("No images found\n");
|
||||
|
||||
exit(EXIT_SUCCESS);
|
||||
}
|
||||
|
||||
void usage()
|
||||
{
|
||||
fprintf (stderr, "Usage:\n"
|
||||
" %s [-o offset] -s size -c count device\n"
|
||||
" -o ==> number of sectors to use as offset\n"
|
||||
" -c ==> number of sectors\n"
|
||||
" -s ==> size of sectors (byte)\n",
|
||||
cmdname);
|
||||
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
static int image_verify_header(char *ptr, int fd)
|
||||
{
|
||||
int len, nread;
|
||||
char *data;
|
||||
uint32_t checksum;
|
||||
image_header_t *hdr = (image_header_t *)ptr;
|
||||
char buf[PAGE_SIZE];
|
||||
|
||||
if (image_get_magic(hdr) != IH_MAGIC)
|
||||
return 0;
|
||||
|
||||
data = (char *)hdr;
|
||||
len = image_get_header_size();
|
||||
|
||||
checksum = image_get_hcrc(hdr);
|
||||
hdr->ih_hcrc = htonl(0); /* clear for re-calculation */
|
||||
|
||||
if (crc32(0, data, len) != checksum) {
|
||||
fprintf(stderr,
|
||||
"%s: Maybe image found but it has bad header checksum!\n",
|
||||
cmdname);
|
||||
return 0;
|
||||
}
|
||||
|
||||
len = image_get_size(hdr);
|
||||
checksum = 0;
|
||||
|
||||
while (len > 0) {
|
||||
nread = read(fd, buf, MIN(len,PAGE_SIZE));
|
||||
if (nread != MIN(len,PAGE_SIZE)) {
|
||||
fprintf(stderr,
|
||||
"%s: Error while reading: %s\n",
|
||||
cmdname, strerror(errno));
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
checksum = crc32(checksum, buf, nread);
|
||||
len -= nread;
|
||||
}
|
||||
|
||||
if (checksum != image_get_dcrc(hdr)) {
|
||||
fprintf (stderr,
|
||||
"%s: Maybe image found but it has corrupted data!\n",
|
||||
cmdname);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
/*
|
||||
* Test for bad block on NAND, just returns 0 on NOR, on NAND:
|
||||
* 0 - block is good
|
||||
* > 0 - block is bad
|
||||
* < 0 - failed to test
|
||||
*/
|
||||
static int flash_bad_block(int fd, uint8_t mtd_type, loff_t start)
|
||||
{
|
||||
if (mtd_type == MTD_NANDFLASH) {
|
||||
int badblock = ioctl(fd, MEMGETBADBLOCK, &start);
|
||||
|
||||
if (badblock < 0) {
|
||||
fprintf(stderr,"%s: Cannot read bad block mark: %s\n",
|
||||
cmdname, strerror(errno));
|
||||
return badblock;
|
||||
}
|
||||
|
||||
if (badblock) {
|
||||
return badblock;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
Loading…
Reference in a new issue