view gsm-fw/lldbg/cmd_r32.c @ 975:0d7cc054ef72

rvinterf/lowlevel: updates for the new knowledge of TM predating ETM
author Mychaela Falconia <falcon@ivan.Harhan.ORG>
date Sun, 15 Nov 2015 04:26:10 +0000
parents f5affe83ba2d
children
line wrap: on
line source

/*
 * r32 hexaddr -- read a 32-bit register or memory location
 */

#include <sys/types.h>
#include "types.h"

void
lldbg_cmd_r32(argbulk)
	char *argbulk;
{
	char *argv[2];
	u_long addr;

	if (lldbg_parse_args(argbulk, 1, 1, argv, 0) < 0)
		return;
	if (lldbg_parse_hexarg(argv[0], 8, &addr) < 0) {
	  lldbg_printf("ERROR: argument must be a valid 32-bit hex address\n");
		return;
	}
	if (addr & 3) {
		lldbg_printf("ERROR: unaligned address\n");
		return;
	}
	lldbg_printf("%08X\n", *(volatile u32 *)addr);
}