diff options
author | Mike Frysinger <vapier@gentoo.org> | 2011-06-06 00:09:12 -0400 |
---|---|---|
committer | Artem Bityutskiy <Artem.Bityutskiy@nokia.com> | 2011-06-06 15:32:43 +0300 |
commit | cd494f74b780729817f7e3e3dd25138e3835eb54 (patch) | |
tree | 0bd8d643a9e17ee237b4cc71dbccb891634a094a /flash_lock.c | |
parent | 6534b670520f7709b2ba73a853a50372653c4726 (diff) |
flash_{lock,unlock}: merge into one util
Now that the utils have equivalent functionality, merge the two source
code bases so they can't diverge in the future.
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Signed-off-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com>
Diffstat (limited to 'flash_lock.c')
-rw-r--r-- | flash_lock.c | 81 |
1 files changed, 3 insertions, 78 deletions
diff --git a/flash_lock.c b/flash_lock.c index 164eaa4..33f76c7 100644 --- a/flash_lock.c +++ b/flash_lock.c @@ -1,83 +1,8 @@ /* - * FILE flash_lock.c - * - * This utility locks one or more sectors of flash device. + * flash_{lock,unlock} * + * utilities for locking/unlocking sectors of flash devices */ #define PROGRAM_NAME "flash_lock" - -#include <unistd.h> -#include <stdlib.h> -#include <stdio.h> -#include <fcntl.h> -#include <time.h> -#include <sys/ioctl.h> -#include <sys/mount.h> -#include <string.h> - -#include <mtd/mtd-user.h> - -int main(int argc, char *argv[]) -{ - int fd; - struct mtd_info_user mtdInfo; - struct erase_info_user mtdLockInfo; - int count; - - /* - * Parse command line options - */ - if (argc < 2) { - fprintf(stderr, "USAGE: %s <mtd device> <offset> <block count>\n", PROGRAM_NAME); - exit(1); - } else if (strncmp(argv[1], "/dev/mtd", 8) != 0) { - fprintf(stderr, "'%s' is not a MTD device. Must specify mtd device: /dev/mtd?\n", argv[1]); - exit(1); - } - - fd = open(argv[1], O_RDWR); - if (fd < 0) { - fprintf(stderr, "Could not open mtd device: %s\n", argv[1]); - exit(1); - } - - if (ioctl(fd, MEMGETINFO, &mtdInfo)) { - fprintf(stderr, "Could not get MTD device info from %s\n", argv[1]); - close(fd); - exit(1); - } - - if (argc > 2) - mtdLockInfo.start = strtol(argv[2], NULL, 0); - else - mtdLockInfo.start = 0; - if (mtdLockInfo.start > mtdInfo.size) { - fprintf(stderr, "%#x is beyond device size %#x\n", - mtdLockInfo.start, mtdInfo.size); - close(fd); - exit(1); - } - - if (argc > 3) { - count = strtol(argv[3], NULL, 0); - if (count == -1) - mtdLockInfo.length = mtdInfo.size - mtdInfo.erasesize; - else - mtdLockInfo.length = mtdInfo.erasesize * count; - } else { - mtdLockInfo.length = mtdInfo.size - mtdInfo.erasesize; - } - if (mtdLockInfo.start + mtdLockInfo.length > mtdInfo.size) { - fprintf(stderr, "lock range is more than device supports\n"); - exit(1); - } - - if (ioctl(fd, MEMLOCK, &mtdLockInfo)) { - fprintf(stderr, "Could not lock MTD device: %s\n", argv[1]); - close(fd); - exit(1); - } - - return 0; -} +#include "flash_unlock.c" |