11da177e4SLinus Torvalds /*
21da177e4SLinus Torvalds * linux/arch/m68k/tools/amiga/dmesg.c -- Retrieve the kernel messages stored
31da177e4SLinus Torvalds * in Chip RAM with the kernel command
41da177e4SLinus Torvalds * line option `debug=mem'.
51da177e4SLinus Torvalds *
696de0e25SJan Engelhardt * © Copyright 1996 by Geert Uytterhoeven <geert@linux-m68k.org>
71da177e4SLinus Torvalds *
81da177e4SLinus Torvalds *
91da177e4SLinus Torvalds * Usage:
101da177e4SLinus Torvalds *
111da177e4SLinus Torvalds * dmesg
121da177e4SLinus Torvalds * dmesg <CHIPMEM_END>
131da177e4SLinus Torvalds *
141da177e4SLinus Torvalds *
151da177e4SLinus Torvalds * This file is subject to the terms and conditions of the GNU General Public
161da177e4SLinus Torvalds * License. See the file COPYING in the main directory of the Linux
171da177e4SLinus Torvalds * distribution for more details.
181da177e4SLinus Torvalds */
191da177e4SLinus Torvalds
201da177e4SLinus Torvalds
211da177e4SLinus Torvalds #include <stdio.h>
221da177e4SLinus Torvalds #include <stdlib.h>
231da177e4SLinus Torvalds #include <unistd.h>
241da177e4SLinus Torvalds
251da177e4SLinus Torvalds
261da177e4SLinus Torvalds #define CHIPMEM_START 0x00000000
271da177e4SLinus Torvalds #define CHIPMEM_END 0x00200000 /* overridden by argv[1] */
281da177e4SLinus Torvalds
291da177e4SLinus Torvalds #define SAVEKMSG_MAGIC1 0x53415645 /* 'SAVE' */
301da177e4SLinus Torvalds #define SAVEKMSG_MAGIC2 0x4B4D5347 /* 'KMSG' */
311da177e4SLinus Torvalds
321da177e4SLinus Torvalds struct savekmsg {
331da177e4SLinus Torvalds u_long magic1; /* SAVEKMSG_MAGIC1 */
341da177e4SLinus Torvalds u_long magic2; /* SAVEKMSG_MAGIC2 */
351da177e4SLinus Torvalds u_long magicptr; /* address of magic1 */
361da177e4SLinus Torvalds u_long size;
37*3381df09SGustavo A. R. Silva char data[];
381da177e4SLinus Torvalds };
391da177e4SLinus Torvalds
401da177e4SLinus Torvalds
main(int argc,char * argv[])411da177e4SLinus Torvalds int main(int argc, char *argv[])
421da177e4SLinus Torvalds {
431da177e4SLinus Torvalds u_long start = CHIPMEM_START, end = CHIPMEM_END, p;
441da177e4SLinus Torvalds int found = 0;
451da177e4SLinus Torvalds struct savekmsg *m = NULL;
461da177e4SLinus Torvalds
471da177e4SLinus Torvalds if (argc >= 2)
481da177e4SLinus Torvalds end = strtoul(argv[1], NULL, 0);
491da177e4SLinus Torvalds printf("Searching for SAVEKMSG magic...\n");
501da177e4SLinus Torvalds for (p = start; p <= end-sizeof(struct savekmsg); p += 4) {
511da177e4SLinus Torvalds m = (struct savekmsg *)p;
521da177e4SLinus Torvalds if ((m->magic1 == SAVEKMSG_MAGIC1) && (m->magic2 == SAVEKMSG_MAGIC2) &&
531da177e4SLinus Torvalds (m->magicptr == p)) {
541da177e4SLinus Torvalds found = 1;
551da177e4SLinus Torvalds break;
561da177e4SLinus Torvalds }
571da177e4SLinus Torvalds }
581da177e4SLinus Torvalds if (!found)
591da177e4SLinus Torvalds printf("Not found\n");
601da177e4SLinus Torvalds else {
611da177e4SLinus Torvalds printf("Found %ld bytes at 0x%08lx\n", m->size, (u_long)&m->data);
621da177e4SLinus Torvalds puts(">>>>>>>>>>>>>>>>>>>>");
631da177e4SLinus Torvalds fflush(stdout);
641da177e4SLinus Torvalds write(1, &m->data, m->size);
651da177e4SLinus Torvalds fflush(stdout);
661da177e4SLinus Torvalds puts("<<<<<<<<<<<<<<<<<<<<");
671da177e4SLinus Torvalds }
681da177e4SLinus Torvalds return(0);
691da177e4SLinus Torvalds }
70