summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZachary T Welch <zw@superlucidity.net>2009-10-24 06:36:05 -0700
committerZachary T Welch <zw@superlucidity.net>2009-11-05 18:03:19 -0800
commitb699aef4c009e705660ee5a0bdfd3a2064fa0a20 (patch)
treef1a8e8de1852439495425ef79ed3aecc0bc29e80
parentf8f1ac886519d8ea4e21572f86a42a223ce72457 (diff)
downloadopenocd+libswd-b699aef4c009e705660ee5a0bdfd3a2064fa0a20.tar.gz
openocd+libswd-b699aef4c009e705660ee5a0bdfd3a2064fa0a20.tar.bz2
openocd+libswd-b699aef4c009e705660ee5a0bdfd3a2064fa0a20.tar.xz
openocd+libswd-b699aef4c009e705660ee5a0bdfd3a2064fa0a20.zip
Improve arm966e command argument parsing.
-rw-r--r--src/target/arm966e.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/src/target/arm966e.c b/src/target/arm966e.c
index c06562c5..5770895b 100644
--- a/src/target/arm966e.c
+++ b/src/target/arm966e.c
@@ -270,7 +270,8 @@ int arm966e_handle_cp15_command(struct command_context_s *cmd_ctx, char *cmd, ch
/* one or more argument, access a single register (write if second argument is given */
if (argc >= 1)
{
- int address = strtoul(args[0], NULL, 0);
+ uint32_t address;
+ COMMAND_PARSE_NUMBER(u32, args[0], address);
if (argc == 1)
{
@@ -289,7 +290,8 @@ int arm966e_handle_cp15_command(struct command_context_s *cmd_ctx, char *cmd, ch
}
else if (argc == 2)
{
- uint32_t value = strtoul(args[1], NULL, 0);
+ uint32_t value;
+ COMMAND_PARSE_NUMBER(u32, args[1], value);
if ((retval = arm966e_write_cp15(target, address, value)) != ERROR_OK)
{
command_print(cmd_ctx, "couldn't access reg %i", address);