blob: 7340f5b6cf6d55dbafe7b86fbf18ff58f4f6ada3 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/arch/m68k/tools/amiga/dmesg.c -- Retrieve the kernel messages stored
3 * in Chip RAM with the kernel command
4 * line option `debug=mem'.
5 *
Jan Engelhardt96de0e22007-10-19 23:21:04 +02006 * © Copyright 1996 by Geert Uytterhoeven <geert@linux-m68k.org>
Linus Torvalds1da177e2005-04-16 15:20:36 -07007 *
8 *
9 * Usage:
10 *
11 * dmesg
12 * dmesg <CHIPMEM_END>
13 *
14 *
15 * This file is subject to the terms and conditions of the GNU General Public
16 * License. See the file COPYING in the main directory of the Linux
17 * distribution for more details.
18 */
19
20
21#include <stdio.h>
22#include <stdlib.h>
23#include <unistd.h>
24
25
26#define CHIPMEM_START 0x00000000
27#define CHIPMEM_END 0x00200000 /* overridden by argv[1] */
28
29#define SAVEKMSG_MAGIC1 0x53415645 /* 'SAVE' */
30#define SAVEKMSG_MAGIC2 0x4B4D5347 /* 'KMSG' */
31
32struct savekmsg {
33 u_long magic1; /* SAVEKMSG_MAGIC1 */
34 u_long magic2; /* SAVEKMSG_MAGIC2 */
35 u_long magicptr; /* address of magic1 */
36 u_long size;
37 char data[0];
38};
39
40
41int main(int argc, char *argv[])
42{
43 u_long start = CHIPMEM_START, end = CHIPMEM_END, p;
44 int found = 0;
45 struct savekmsg *m = NULL;
46
47 if (argc >= 2)
48 end = strtoul(argv[1], NULL, 0);
49 printf("Searching for SAVEKMSG magic...\n");
50 for (p = start; p <= end-sizeof(struct savekmsg); p += 4) {
51 m = (struct savekmsg *)p;
52 if ((m->magic1 == SAVEKMSG_MAGIC1) && (m->magic2 == SAVEKMSG_MAGIC2) &&
53 (m->magicptr == p)) {
54 found = 1;
55 break;
56 }
57 }
58 if (!found)
59 printf("Not found\n");
60 else {
61 printf("Found %ld bytes at 0x%08lx\n", m->size, (u_long)&m->data);
62 puts(">>>>>>>>>>>>>>>>>>>>");
63 fflush(stdout);
64 write(1, &m->data, m->size);
65 fflush(stdout);
66 puts("<<<<<<<<<<<<<<<<<<<<");
67 }
68 return(0);
69}