Annotation of sys/arch/arm/arm/stubs.c, Revision 1.1.1.1
1.1 nbrk 1: /* $OpenBSD: stubs.c,v 1.5 2007/06/06 17:15:11 deraadt Exp $ */
2: /* $NetBSD: stubs.c,v 1.14 2003/07/15 00:24:42 lukem Exp $ */
3:
4: /*
5: * Copyright (c) 1994-1998 Mark Brinicombe.
6: * Copyright (c) 1994 Brini.
7: * All rights reserved.
8: *
9: * This code is derived from software written for Brini by Mark Brinicombe
10: *
11: * Redistribution and use in source and binary forms, with or without
12: * modification, are permitted provided that the following conditions
13: * are met:
14: * 1. Redistributions of source code must retain the above copyright
15: * notice, this list of conditions and the following disclaimer.
16: * 2. Redistributions in binary form must reproduce the above copyright
17: * notice, this list of conditions and the following disclaimer in the
18: * documentation and/or other materials provided with the distribution.
19: * 3. All advertising materials mentioning features or use of this software
20: * must display the following acknowledgement:
21: * This product includes software developed by Mark Brinicombe
22: * for the NetBSD Project.
23: * 4. The name of the company nor the name of the author may be used to
24: * endorse or promote products derived from this software without specific
25: * prior written permission.
26: *
27: * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
28: * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
29: * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
30: * IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
31: * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
32: * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
33: * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
34: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
35: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
36: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
37: * SUCH DAMAGE.
38: *
39: * Routines that are temporary or do not have a home yet.
40: *
41: * Created : 17/09/94
42: */
43:
44: #include <sys/param.h>
45: #include <sys/systm.h>
46: #include <sys/errno.h>
47: #include <sys/proc.h>
48: #include <sys/conf.h>
49: #include <sys/msgbuf.h>
50: #include <sys/exec.h>
51: #include <sys/core.h>
52: #include <sys/kcore.h>
53: #include <uvm/uvm_extern.h>
54: #include <machine/bootconfig.h>
55: #include <machine/cpu.h>
56: #include <machine/intr.h>
57: #include <machine/pcb.h>
58: #include <arm/kcore.h>
59: #include <arm/machdep.h>
60:
61: extern dev_t dumpdev;
62:
63: /*
64: * These variables are needed by /sbin/savecore
65: */
66: u_int32_t dumpmag = 0x8fca0101; /* magic number */
67: int dumpsize = 0; /* pages */
68: long dumplo = 0; /* blocks */
69: cpu_kcore_hdr_t cpu_kcore_hdr;
70: struct pcb dumppcb;
71:
72: /*
73: * This is called by main to set dumplo and dumpsize.
74: * Dumps always skip the first CLBYTES of disk space
75: * in case there might be a disk label stored there.
76: * If there is extra space, put dump at the end to
77: * reduce the chance that swapping trashes it.
78: */
79:
80: void dumpconf(void);
81:
82: void
83: dumpconf(void)
84: {
85: int nblks, block;
86:
87: if (dumpdev == NODEV ||
88: (nblks = (bdevsw[major(dumpdev)].d_psize)(dumpdev)) == 0)
89: return;
90: if (nblks <= ctod(1))
91: return;
92:
93: dumpsize = physmem;
94:
95: /* Always skip the first CLBYTES, in case there is a label there. */
96: if (dumplo < ctod(1))
97: dumplo = ctod(1);
98:
99: /* Put dump at end of partition, and make it fit. */
100: if (dumpsize + 1 > dtoc(nblks - dumplo))
101: dumpsize = dtoc(nblks - dumplo) - 1;
102: if (dumplo < nblks - ctod(dumpsize) - 1)
103: dumplo = nblks - ctod(dumpsize) - 1;
104:
105: for (block = 0; block < bootconfig.dramblocks; block++) {
106: cpu_kcore_hdr.ram_segs[block].start =
107: bootconfig.dram[block].address;
108: cpu_kcore_hdr.ram_segs[block].size =
109: ptoa(bootconfig.dram[block].pages);
110: }
111: }
112:
113: /* This should be moved to machdep.c */
114:
115: extern char *memhook; /* XXX */
116:
117: /*
118: * Doadump comes here after turning off memory management and
119: * getting on the dump stack, either when called above, or by
120: * the auto-restart code.
121: */
122:
123: void
124: dumpsys()
125: {
126: const struct bdevsw *bdev;
127: daddr64_t blkno;
128: int psize;
129: int error;
130: int addr;
131: int block;
132: int len;
133: vaddr_t dumpspace;
134: kcore_seg_t *kseg_p;
135: cpu_kcore_hdr_t *chdr_p;
136: char dump_hdr[dbtob(1)]; /* assumes header fits in one block */
137:
138: /* Save registers. */
139: savectx(&dumppcb);
140: /* flush everything out of caches */
141: cpu_dcache_wbinv_all();
142:
143: if (dumpdev == NODEV)
144: return;
145: if (dumpsize == 0) {
146: dumpconf();
147: if (dumpsize == 0)
148: return;
149: }
150: if (dumplo <= 0) {
151: printf("\ndump to dev %u,%u not possible\n", major(dumpdev),
152: minor(dumpdev));
153: return;
154: }
155: printf("\ndumping to dev %u,%u offset %ld\n", major(dumpdev),
156: minor(dumpdev), dumplo);
157:
158: blkno = dumplo;
159: dumpspace = (vaddr_t) memhook;
160:
161: bdev = bdevsw_lookup(dumpdev);
162: if (bdev == NULL || bdev->d_psize == NULL)
163: return;
164: psize = (*bdev->d_psize)(dumpdev);
165: printf("dump ");
166: if (psize == -1) {
167: printf("area unavailable\n");
168: return;
169: }
170:
171: /* Setup the dump header */
172: kseg_p = (kcore_seg_t *)dump_hdr;
173: chdr_p = (cpu_kcore_hdr_t *)&dump_hdr[ALIGN(sizeof(*kseg_p))];
174: bzero(dump_hdr, sizeof(dump_hdr));
175:
176: CORE_SETMAGIC(*kseg_p, KCORE_MAGIC, MID_MACHINE, CORE_CPU);
177: kseg_p->c_size = sizeof(dump_hdr) - ALIGN(sizeof(*kseg_p));
178: *chdr_p = cpu_kcore_hdr;
179:
180: error = (*bdev->d_dump)(dumpdev, blkno++, (caddr_t)dump_hdr,
181: sizeof(dump_hdr));
182: if (error != 0)
183: goto abort;
184:
185: len = 0;
186: for (block = 0; block < bootconfig.dramblocks && error == 0; ++block) {
187: addr = bootconfig.dram[block].address;
188: for (;addr < (bootconfig.dram[block].address
189: + (bootconfig.dram[block].pages * PAGE_SIZE));
190: addr += PAGE_SIZE) {
191: if ((len % (1024*1024)) == 0)
192: printf("%d ", len / (1024*1024));
193: pmap_kenter_pa(dumpspace, addr, VM_PROT_READ);
194: pmap_update(pmap_kernel());
195:
196: error = (*bdev->d_dump)(dumpdev,
197: blkno, (caddr_t) dumpspace, PAGE_SIZE);
198: pmap_kremove(dumpspace, PAGE_SIZE);
199: pmap_update(pmap_kernel());
200: if (error) break;
201: blkno += btodb(PAGE_SIZE);
202: len += PAGE_SIZE;
203: }
204: }
205:
206: abort:
207: switch (error) {
208: case ENXIO:
209: printf("device bad\n");
210: break;
211:
212: case EFAULT:
213: printf("device not ready\n");
214: break;
215:
216: case EINVAL:
217: printf("area improper\n");
218: break;
219:
220: case EIO:
221: printf("i/o error\n");
222: break;
223:
224: case EINTR:
225: printf("aborted from console\n");
226: break;
227:
228: default:
229: printf("succeeded\n");
230: break;
231: }
232: printf("\n\n");
233: delay(1000000);
234: }
235:
236: /* End of stubs.c */
CVSweb