xref: /openbmc/linux/arch/m68k/tools/amiga/dmesg.c (revision 4b4193256c8d3bc3a5397b5cd9494c2ad386317d)
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