# HG changeset patch # User Mychaela Falconia # Date 1701561007 0 # Node ID 676203b4bf3393fca506447ff97a802ef221ecc4 # Parent d50df222c2746f722df774b360c7a40710780300 pln-ppb-test: implement mode-entry diff -r d50df222c274 -r 676203b4bf33 target-utils/pln-ppb-test/Makefile --- a/target-utils/pln-ppb-test/Makefile Sat Dec 02 23:39:33 2023 +0000 +++ b/target-utils/pln-ppb-test/Makefile Sat Dec 02 23:50:07 2023 +0000 @@ -5,7 +5,7 @@ OBJCOPY=arm-elf-objcopy PROG= pln-ppb-test -OBJS= crt0.o cmdtab.o main.o +OBJS= crt0.o cmdtab.o main.o mode_entry.o LIBS= ../libcommon/libcommon.a ../libprintf/libprintf.a \ ../libbase/libbase.a ../libc/libc.a LIBGCC= `${CC} -print-file-name=libgcc.a` diff -r d50df222c274 -r 676203b4bf33 target-utils/pln-ppb-test/cmdtab.c --- a/target-utils/pln-ppb-test/cmdtab.c Sat Dec 02 23:39:33 2023 +0000 +++ b/target-utils/pln-ppb-test/cmdtab.c Sat Dec 02 23:50:07 2023 +0000 @@ -3,6 +3,7 @@ extern void cmd_abbr(); extern void cmd_abbw(); extern void cmd_jump(); +extern void cmd_mode_entry(); extern void cmd_r8(); extern void cmd_r16(); extern void cmd_r32(); @@ -25,6 +26,7 @@ {"baud", cmd_baud_switch}, {"dump", cmd_memdump_human}, {"jump", cmd_jump}, + {"mode-entry", cmd_mode_entry}, {"poweroff", abb_power_off}, {"r8", cmd_r8}, {"r16", cmd_r16}, diff -r d50df222c274 -r 676203b4bf33 target-utils/pln-ppb-test/mode_entry.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target-utils/pln-ppb-test/mode_entry.c Sat Dec 02 23:50:07 2023 +0000 @@ -0,0 +1,32 @@ +/* + * mode-entry and mode-exit commands + */ + +#include +#include "types.h" + +void +cmd_mode_entry(argbulk) + char *argbulk; +{ + char *argv[3]; + u_long addr, mode; + + if (parse_args(argbulk, 2, 2, argv, 0) < 0) + return; + if (parse_hexarg(argv[0], 8, &addr) < 0) { + printf("ERROR: arg1 must be a valid 32-bit hex address\n"); + return; + } + if (addr & 0xFFFF) { + printf("ERROR: address is not on 64 KiB boundary\n"); + return; + } + if (parse_hexarg(argv[1], 4, &mode) < 0) { + printf("ERROR: arg2 must be a valid 16-bit hex value\n"); + return; + } + *(volatile u16 *)(addr + 0xAAA) = 0xAA; + *(volatile u16 *)(addr + 0x554) = 0x55; + *(volatile u16 *)(addr + 0xAAA) = mode; +}