9
0
Fork 0
barebox/commands/flash.c

210 lines
4.9 KiB
C
Raw Normal View History

2002-09-18 12:49:44 +00:00
/*
2007-10-16 17:07:21 +00:00
* erase, protect, unprotect - FLASH support
*
2002-09-18 12:49:44 +00:00
* (C) Copyright 2000
* Wolfgang Denk, DENX Software Engineering, wd@denx.de.
*
* See file CREDITS for list of people who contributed to this
* project.
*
* 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
*/
/**
* @file
* @brief Flash memory support: erase, protect, unprotect
*/
2002-09-18 12:49:44 +00:00
#include <common.h>
#include <command.h>
2007-07-05 16:01:24 +00:00
#include <cfi_flash.h>
2007-07-05 16:01:48 +00:00
#include <errno.h>
2007-07-05 16:01:55 +00:00
#include <getopt.h>
#include <fs.h>
#include <fcntl.h>
#include <linux/stat.h>
2007-09-28 08:07:26 +00:00
static int do_flerase (cmd_tbl_t *cmdtp, int argc, char *argv[])
2002-09-18 12:49:44 +00:00
{
int fd;
2007-07-05 16:01:55 +00:00
char *filename = NULL;
struct stat s;
unsigned long start = 0, size = ~0;
int ret = 0;
2002-09-18 12:49:44 +00:00
if (argc == 1) {
u_boot_cmd_usage(cmdtp);
return 1;
2007-07-05 16:01:55 +00:00
}
filename = argv[1];
2007-07-05 16:01:55 +00:00
if (stat(filename, &s)) {
2007-07-14 12:45:45 +00:00
printf("stat %s: %s\n", filename, errno_str());
2002-09-18 12:49:44 +00:00
return 1;
}
2007-07-05 16:01:39 +00:00
2007-07-05 16:01:55 +00:00
size = s.st_size;
if (!filename) {
printf("missing filename\n");
return 1;
}
fd = open(filename, O_WRONLY);
if (fd < 0) {
printf("open %s:", filename, errno_str());
return 1;
}
if (argc == 3 && parse_area_spec(argv[2], &start, &size)) {
printf("could not parse: %s\n", argv[optind]);
ret = 1;
goto out;
}
2007-07-05 16:01:55 +00:00
if (erase(fd, size, start)) {
perror("erase");
ret = 1;
}
out:
2007-07-05 16:01:55 +00:00
close(fd);
return ret;
2002-09-18 12:49:44 +00:00
}
static const __maybe_unused char cmd_erase_help[] =
"Usage: Erase <device> [area]\n"
"Erase a flash device or parts of a device if an area specification\n"
"is given\n";
U_BOOT_CMD_START(erase)
2007-07-05 16:01:55 +00:00
.maxargs = CONFIG_MAXARGS,
.cmd = do_flerase,
.usage = "erase FLASH memory",
U_BOOT_CMD_HELP(cmd_erase_help)
U_BOOT_CMD_END
/** @page erase_command erase Erase flash memory
*
* Usage is: erase \<devicee>
*
* Erase the flash memory behind the device. It depends on the device given,
* what area will be erased. If the device represents the whole flash memory
* the whole memory will be erased. If the device represents a partition on
* a main flash memory, only this partition part will be erased.
*
* Refer \b addpart, \b delpart and \b devinfo for partition handling.
*/
2007-09-28 08:07:26 +00:00
static int do_protect (cmd_tbl_t *cmdtp, int argc, char *argv[])
2002-09-18 12:49:44 +00:00
{
int fd;
2007-07-16 08:29:28 +00:00
char *filename = NULL;
struct stat s;
int prot = 1;
unsigned long start = 0, size = ~0;
int ret = 0;
2007-07-16 08:29:28 +00:00
if (argc == 1) {
u_boot_cmd_usage(cmdtp);
return 1;
2007-07-16 08:29:28 +00:00
}
filename = argv[1];
2007-07-16 08:29:28 +00:00
if (*argv[0] == 'u')
prot = 0;
2007-07-16 08:29:28 +00:00
if (stat(filename, &s)) {
printf("stat %s: %s\n", filename, errno_str());
2002-09-18 12:49:44 +00:00
return 1;
}
2007-07-16 08:29:28 +00:00
size = s.st_size;
if (!filename) {
printf("missing filename\n");
return 1;
}
fd = open(filename, O_WRONLY);
if (fd < 0) {
printf("open %s:", filename, errno_str());
2002-09-18 12:49:44 +00:00
return 1;
}
2007-07-05 16:01:39 +00:00
if (argc == 3)
if (parse_area_spec(argv[2], &start, &size)) {
printf("could not parse: %s\n", argv[optind]);
ret = 1;
goto out;
}
2007-07-16 08:29:28 +00:00
if(protect(fd, size, start, prot)) {
perror("protect");
ret = 1;
goto out;
2002-09-18 12:49:44 +00:00
}
out:
2007-07-16 08:29:28 +00:00
close(fd);
return ret;
2002-09-18 12:49:44 +00:00
}
static const __maybe_unused char cmd_protect_help[] =
"Usage: (un)protect <device> [area]\n"
"(un)protect a flash device or parts of a device if an area specification\n"
"is given\n";
U_BOOT_CMD_START(protect)
.maxargs = 4,
.cmd = do_protect,
2007-07-16 08:29:28 +00:00
.usage = "enable FLASH write protection",
U_BOOT_CMD_HELP(cmd_protect_help)
U_BOOT_CMD_END
2007-07-16 08:29:28 +00:00
U_BOOT_CMD_START(unprotect)
.maxargs = 4,
.cmd = do_protect,
.usage = "disable FLASH write protection",
U_BOOT_CMD_HELP(cmd_protect_help)
2007-07-16 08:29:28 +00:00
U_BOOT_CMD_END
/** @page protect_command protect Protect a flash memory
*
* Usage is: protect \<devicee>
*
* Protect the flash memory behind the device. It depends on the device given,
* what area will be protected. If the device represents the whole flash memory
* the whole memory will be protected. If the device represents a partition on
* a main flash memory, only this partition part will be protected.
*
* Refer \b addpart, \b delpart and \b devinfo for partition handling.
*/
/** @page unprotect_command unprotect Unprotect a flash memory
*
* Usage is: unprotect \<devicee>
*
* Unprotect the flash memory behind the device. It depends on the device given,
* what area will be unprotected. If the device represents the whole flash memory
* the whole memory will be unprotected. If the device represents a partition
* on a main flash memory, only this partition part will be unprotected.
*
* Refer \b addpart, \b delpart and \b devinfo for partition handling.
*/