Home | History | Annotate | Line # | Download | only in libkvm
kvm_hppa.c revision 1.6.12.1
      1  1.6.12.1       tls /*	$NetBSD: kvm_hppa.c,v 1.6.12.1 2014/08/20 00:02:17 tls Exp $	*/
      2       1.1  fredette 
      3       1.1  fredette /*-
      4       1.1  fredette  * Copyright (c) 1989, 1992, 1993
      5       1.1  fredette  *	The Regents of the University of California.  All rights reserved.
      6       1.1  fredette  *
      7       1.1  fredette  * This code is derived from software developed by the Computer Systems
      8       1.1  fredette  * Engineering group at Lawrence Berkeley Laboratory under DARPA contract
      9       1.1  fredette  * BG 91-66 and contributed to Berkeley.
     10       1.1  fredette  *
     11       1.1  fredette  * Redistribution and use in source and binary forms, with or without
     12       1.1  fredette  * modification, are permitted provided that the following conditions
     13       1.1  fredette  * are met:
     14       1.1  fredette  * 1. Redistributions of source code must retain the above copyright
     15       1.1  fredette  *    notice, this list of conditions and the following disclaimer.
     16       1.1  fredette  * 2. Redistributions in binary form must reproduce the above copyright
     17       1.1  fredette  *    notice, this list of conditions and the following disclaimer in the
     18       1.1  fredette  *    documentation and/or other materials provided with the distribution.
     19       1.2       agc  * 3. Neither the name of the University nor the names of its contributors
     20       1.1  fredette  *    may be used to endorse or promote products derived from this software
     21       1.1  fredette  *    without specific prior written permission.
     22       1.1  fredette  *
     23       1.1  fredette  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     24       1.1  fredette  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     25       1.1  fredette  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     26       1.1  fredette  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     27       1.1  fredette  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     28       1.1  fredette  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     29       1.1  fredette  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     30       1.1  fredette  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     31       1.1  fredette  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     32       1.1  fredette  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     33       1.1  fredette  * SUCH DAMAGE.
     34       1.1  fredette  */
     35       1.1  fredette 
     36       1.1  fredette #include <sys/cdefs.h>
     37       1.1  fredette #if defined(LIBC_SCCS) && !defined(lint)
     38       1.1  fredette #if 0
     39       1.1  fredette static char sccsid[] = "@(#)kvm_hp300.c	8.1 (Berkeley) 6/4/93";
     40       1.1  fredette #else
     41  1.6.12.1       tls __RCSID("$NetBSD: kvm_hppa.c,v 1.6.12.1 2014/08/20 00:02:17 tls Exp $");
     42       1.1  fredette #endif
     43       1.1  fredette #endif /* LIBC_SCCS and not lint */
     44       1.1  fredette 
     45       1.1  fredette /*
     46       1.1  fredette  * hppa machine dependent routines for kvm.
     47       1.1  fredette  * XXX fredette - largely unimplemented so far.  what is here
     48       1.1  fredette  * is lifted and disabled.
     49       1.1  fredette  */
     50       1.1  fredette 
     51       1.1  fredette #include <sys/param.h>
     52       1.1  fredette #include <sys/proc.h>
     53       1.1  fredette #include <sys/stat.h>
     54       1.1  fredette #include <sys/kcore.h>
     55       1.6       jym #include <sys/types.h>
     56       1.6       jym 
     57       1.1  fredette #include <stdlib.h>
     58       1.1  fredette #include <unistd.h>
     59       1.1  fredette #include <nlist.h>
     60       1.1  fredette #include <kvm.h>
     61       1.1  fredette 
     62       1.1  fredette #include <uvm/uvm_extern.h>
     63       1.1  fredette 
     64       1.1  fredette #include <limits.h>
     65       1.1  fredette #include <db.h>
     66       1.1  fredette 
     67       1.1  fredette #include "kvm_private.h"
     68       1.1  fredette 
     69       1.6       jym #include <machine/kcore.h>
     70       1.1  fredette #include <machine/pmap.h>
     71       1.1  fredette #include <machine/pte.h>
     72       1.1  fredette #include <machine/vmparam.h>
     73       1.1  fredette 
     74       1.1  fredette #ifndef btop
     75       1.1  fredette #define	btop(x)		(((unsigned)(x)) >> PGSHIFT)	/* XXX */
     76       1.1  fredette #define	ptob(x)		((caddr_t)((x) << PGSHIFT))	/* XXX */
     77       1.1  fredette #endif
     78       1.1  fredette 
     79       1.1  fredette void
     80       1.4     skrll _kvm_freevtop(kvm_t *kd)
     81       1.1  fredette {
     82       1.1  fredette 
     83       1.1  fredette 	/* Not actually used for anything right now, but safe. */
     84       1.1  fredette 	if (kd->vmst != 0)
     85       1.1  fredette 		free(kd->vmst);
     86       1.1  fredette }
     87       1.1  fredette 
     88       1.1  fredette /*ARGSUSED*/
     89       1.1  fredette int
     90       1.4     skrll _kvm_initvtop(kvm_t *kd)
     91       1.1  fredette {
     92       1.1  fredette 
     93       1.4     skrll 	return 0;
     94       1.1  fredette }
     95       1.1  fredette 
     96       1.1  fredette /*
     97       1.1  fredette  * Translate a kernel virtual address to a physical address.
     98       1.1  fredette  */
     99       1.1  fredette int
    100       1.6       jym _kvm_kvatop(kvm_t *kd, vaddr_t va, paddr_t *pa)
    101       1.1  fredette {
    102       1.1  fredette #if 0
    103       1.1  fredette 	cpu_kcore_hdr_t *cpu_kh;
    104       1.1  fredette 	u_long page_off;
    105       1.1  fredette 	pd_entry_t pde;
    106       1.1  fredette 	pt_entry_t pte;
    107       1.1  fredette 	u_long pde_pa, pte_pa;
    108       1.1  fredette #endif
    109       1.1  fredette 
    110       1.1  fredette 	if (ISALIVE(kd)) {
    111       1.1  fredette 		_kvm_err(kd, 0, "vatop called in live kernel!");
    112       1.5     skrll 		return 0;
    113       1.1  fredette 	}
    114       1.1  fredette 
    115       1.1  fredette 	_kvm_syserr(kd, 0, "could not read PTE");
    116       1.1  fredette 
    117       1.1  fredette #if 0
    118       1.1  fredette 	cpu_kh = kd->cpu_data;
    119       1.1  fredette 	page_off = va & PGOFSET;
    120       1.1  fredette 
    121       1.1  fredette 	/*
    122       1.1  fredette 	 * Find and read the page directory entry.
    123       1.1  fredette 	 */
    124       1.1  fredette 	pde_pa = cpu_kh->ptdpaddr + (pdei(va) * sizeof(pd_entry_t));
    125       1.3        ad 	if (_kvm_pread(kd, kd->pmfd, (void *)&pde, sizeof(pde),
    126       1.1  fredette 	    _kvm_pa2off(kd, pde_pa)) != sizeof(pde)) {
    127       1.1  fredette 		_kvm_syserr(kd, 0, "could not read PDE");
    128       1.1  fredette 		goto lose;
    129       1.1  fredette 	}
    130       1.1  fredette 
    131       1.1  fredette 	/*
    132       1.1  fredette 	 * Find and read the page table entry.
    133       1.1  fredette 	 */
    134       1.1  fredette 	if ((pde & PG_V) == 0) {
    135       1.1  fredette 		_kvm_err(kd, 0, "invalid translation (invalid PDE)");
    136       1.1  fredette 		goto lose;
    137       1.1  fredette 	}
    138       1.1  fredette 	pte_pa = (pde & PG_FRAME) + (ptei(va) * sizeof(pt_entry_t));
    139       1.3        ad 	if (_kvm_pread(kd, kd->pmfd, (void *) &pte, sizeof(pte),
    140       1.1  fredette 	    _kvm_pa2off(kd, pte_pa)) != sizeof(pte)) {
    141       1.1  fredette 		_kvm_syserr(kd, 0, "could not read PTE");
    142       1.1  fredette 		goto lose;
    143       1.1  fredette 	}
    144       1.1  fredette 
    145       1.1  fredette 	/*
    146       1.1  fredette 	 * Validate the PTE and return the physical address.
    147       1.1  fredette 	 */
    148       1.1  fredette 	if ((pte & PG_V) == 0) {
    149       1.1  fredette 		_kvm_err(kd, 0, "invalid translation (invalid PTE)");
    150       1.1  fredette 		goto lose;
    151       1.1  fredette 	}
    152       1.1  fredette 	*pa = (pte & PG_FRAME) + page_off;
    153       1.1  fredette 	return (int)(NBPG - page_off);
    154       1.1  fredette 
    155       1.1  fredette  lose:
    156       1.1  fredette #endif
    157       1.1  fredette 	*pa = (u_long)~0L;
    158       1.4     skrll 	return 0;
    159       1.1  fredette }
    160       1.1  fredette 
    161       1.1  fredette /*
    162       1.1  fredette  * Translate a physical address to a file-offset in the crash dump.
    163       1.1  fredette  */
    164       1.1  fredette off_t
    165       1.6       jym _kvm_pa2off(kvm_t *kd, paddr_t pa)
    166       1.1  fredette {
    167       1.1  fredette #if 0
    168       1.1  fredette 	cpu_kcore_hdr_t *cpu_kh;
    169       1.1  fredette 	phys_ram_seg_t *ramsegs;
    170       1.1  fredette 	off_t off;
    171       1.1  fredette 	int i;
    172       1.1  fredette 
    173       1.1  fredette 	cpu_kh = kd->cpu_data;
    174       1.1  fredette 	ramsegs = (void *)((char *)(void *)cpu_kh + ALIGN(sizeof *cpu_kh));
    175       1.1  fredette 
    176       1.1  fredette 	off = 0;
    177       1.1  fredette 	for (i = 0; i < cpu_kh->nmemsegs; i++) {
    178       1.1  fredette 		if (pa >= ramsegs[i].start &&
    179       1.1  fredette 		    (pa - ramsegs[i].start) < ramsegs[i].size) {
    180       1.1  fredette 			off += (pa - ramsegs[i].start);
    181       1.1  fredette 			break;
    182       1.1  fredette 		}
    183       1.1  fredette 		off += ramsegs[i].size;
    184       1.1  fredette 	}
    185       1.1  fredette 
    186       1.4     skrll 	return kd->dump_off + off;
    187       1.1  fredette #endif
    188       1.1  fredette 	return 0;
    189       1.1  fredette }
    190       1.1  fredette 
    191       1.1  fredette /*
    192       1.1  fredette  * Machine-dependent initialization for ALL open kvm descriptors,
    193       1.1  fredette  * not just those for a kernel crash dump.  Some architectures
    194       1.1  fredette  * have to deal with these NOT being constants!  (i.e. m68k)
    195       1.1  fredette  */
    196       1.1  fredette int
    197       1.4     skrll _kvm_mdopen(kvm_t *kd)
    198       1.1  fredette {
    199       1.1  fredette 
    200       1.1  fredette 	kd->usrstack = USRSTACK;
    201       1.1  fredette 	kd->min_uva = VM_MIN_ADDRESS;
    202       1.1  fredette 	kd->max_uva = VM_MAXUSER_ADDRESS;
    203       1.1  fredette 
    204       1.4     skrll 	return 0;
    205       1.1  fredette }
    206