Home | History | Annotate | Line # | Download | only in common
      1  1.10       mrg /* $NetBSD: OSFpal.c,v 1.10 2021/04/12 09:18:45 mrg Exp $ */
      2   1.1       cgd 
      3   1.1       cgd /*
      4   1.1       cgd  * Copyright (c) 1994, 1996 Carnegie-Mellon University.
      5   1.1       cgd  * All rights reserved.
      6   1.1       cgd  *
      7   1.1       cgd  * Author: Keith Bostic
      8   1.1       cgd  *
      9   1.1       cgd  * Permission to use, copy, modify and distribute this software and
     10   1.1       cgd  * its documentation is hereby granted, provided that both the copyright
     11   1.1       cgd  * notice and this permission notice appear in all copies of the
     12   1.1       cgd  * software, derivative works or modified versions, and any portions
     13   1.1       cgd  * thereof, and that both notices appear in supporting documentation.
     14   1.1       cgd  *
     15   1.1       cgd  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
     16   1.1       cgd  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
     17   1.1       cgd  * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
     18   1.1       cgd  *
     19   1.1       cgd  * Carnegie Mellon requests users of this software to return to
     20   1.1       cgd  *
     21   1.1       cgd  *  Software Distribution Coordinator  or  Software.Distribution (at) CS.CMU.EDU
     22   1.1       cgd  *  School of Computer Science
     23   1.1       cgd  *  Carnegie Mellon University
     24   1.1       cgd  *  Pittsburgh PA 15213-3890
     25   1.1       cgd  *
     26   1.1       cgd  * any improvements or extensions that they make and grant Carnegie the
     27   1.1       cgd  * rights to redistribute these changes.
     28   1.1       cgd  */
     29   1.1       cgd 
     30   1.1       cgd #include <sys/types.h>
     31   1.3  drochner #include <lib/libsa/stand.h>
     32   1.1       cgd 
     33   1.1       cgd #include <machine/prom.h>
     34   1.1       cgd #include <machine/rpb.h>
     35   1.4      ross #include <machine/alpha_cpu.h>
     36   1.4      ross 
     37  1.10       mrg /* XXX */
     38  1.10       mrg extern paddr_t ptbr_save;
     39   1.1       cgd 
     40   1.3  drochner #include "common.h"
     41   1.3  drochner 
     42   1.1       cgd void
     43   1.9    cegger OSFpal(void)
     44   1.1       cgd {
     45   1.1       cgd 	struct rpb *r;
     46   1.1       cgd 	struct pcs *p;
     47   1.1       cgd 
     48   1.1       cgd 	r = (struct rpb *)HWRPB_ADDR;
     49   1.4      ross 	/*
     50   1.4      ross 	 * Note, cpu_number() is a VMS op, can't necessarily call it.
     51   1.4      ross 	 * Real fun: PAL_VMS_mfpr_whami == PAL_OSF1_rti...
     52   1.4      ross 	 * We might not be rpb_primary_cpu_id, but it is supposed to go
     53   1.4      ross 	 * first so the answer should apply to everyone.
     54   1.4      ross 	 */
     55   1.5      ross 	p = LOCATE_PCS(r, r->rpb_primary_cpu_id);
     56   1.1       cgd 
     57   1.4      ross 	printf("VMS PAL rev: 0x%lx\n", p->pcs_palrevisions[PALvar_OpenVMS]);
     58   1.1       cgd 	printf("OSF PAL rev: 0x%lx\n", p->pcs_palrevisions[PALvar_OSF1]);
     59   1.4      ross 
     60   1.4      ross 	if(p->pcs_pal_type==PAL_TYPE_OSF1) {
     61   1.4      ross 		printf("OSF PAL code already running.\n");
     62   1.4      ross 		ptbr_save = ((struct alpha_pcb *)p)->apcb_ptbr;
     63   1.4      ross 		printf("PTBR is:          0x%lx\n", ptbr_save);
     64   1.4      ross 		return;
     65   1.4      ross 	}
     66   1.3  drochner 	switch_palcode();
     67   1.8       wiz 	memcpy(&p->pcs_pal_rev, &p->pcs_palrevisions[PALvar_OSF1],
     68   1.7   thorpej 	    sizeof(p->pcs_pal_rev));
     69   1.1       cgd 	printf("Switch to OSF PAL code succeeded.\n");
     70   1.1       cgd }
     71   1.1       cgd 
     72