Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 17 Dec 2003 12:45:37 +0200
From:      Danny Braniss <danny@cs.huji.ac.il>
To:        John Birrell <jb@cimlogic.com.au>
Cc:        Freebsd Current <current@freebsd.org>
Subject:   Re: SC520 and reboot 
Message-ID:  <E1AWZBS-0002cO-2V@cs.huji.ac.il>
In-Reply-To: Your message of Sun, 14 Dec 2003 08:29:13 %2B1100 .

next in thread | raw e-mail | index | archive | help

> My Compulab board doesn't reset the bios. Reboot (or shutdown -r) on FreeBSD
> causes the board to power down, not reboot. The documented way to cause a
> reboot with the Elan SC520 chip is to set SYS_RST in the MMCR.
> 
> In sys/i386/i386/machdep.c:cpu_reset_real() I've added:
> 
> #ifdef  CPU_ELAN
>     if (elan_mmcr != NULL)
>         /* SYS_RST */
>         elan_mmcr->RESCFG = 1;
> #endif
> 

the file is sys/i386/i386/vm_machdep.c, which was easy to find out, but what
took time to fix was that it needed an #include "opt_cpu.h"

so now it rebooting nicely.

thanks,
	danny


> vm_
> This causes the reboot to behave normally.
> 
> For convenience, I use the following structure to access the Elan SC520
> memory mapped configuration region instead of the opaque uint16_t array
> that phk uses. This changes lines like:
> 
> elan_mmcr[0xc82 / 2] = 0xc001;
> 
> to
> 
> elan_mmcr->GPTMR2CTL = 0xc001;
> 
> which is more intuitive to me when reading the AMD register set manual.
> 
> /*
>  * AMD Elan SC520 Memory Mapped Configuration Region (MMCR).
>  *
>  * The layout of this structure is documented by AMD in the Elan SC520
>  * Microcontroller Register Set Manual. The field names match those
>  * described in that document. The overall structure size must be 4096
>  * bytes. Ignore fields with the 'pad' prefix - they are only present for
>  * alignment purposes.
>  */
> struct elan_mmcr {
> 	/* CPU */
> 	u_int16_t	REVID;
> 	u_int8_t	CPUCTL;
> 	u_int8_t	pad_0x003[0xd];
> 
> 	/* SDRAM Controller */
> 	u_int16_t	DRCCTL;
> 	u_int16_t	DRCTMCTL;
> 	u_int16_t	DRCCFG;
> 	u_int16_t	DRCBENDADR;
> 	u_int8_t	pad_0x01a[0x6];
> 	u_int8_t	ECCCTL;
> 	u_int8_t	ECCSTA;
> 	u_int8_t	ECCCKBPOS;
> 	u_int8_t	ECCCKTEST;
> 	u_int32_t	ECCSBADD;
> 	u_int32_t	ECCMBADD;
> 	u_int8_t	pad_0x02c[0x14];
> 
> 	/* SDRAM Buffer */
> 	u_int8_t	DBCTL;
> 	u_int8_t	pad_0x041[0xf];
> 
> 	/* ROM/Flash Controller */
> 	u_int16_t	BOOTCSCTL;
> 	u_int8_t	pad_0x052[0x2];
> 	u_int16_t	ROMCS1CTL;
> 	u_int16_t	ROMCS2CTL;
> 	u_int8_t	pad_0x058[0x8];
> 
> 	/* PCI Bus Host Bridge */
> 	u_int16_t	HBCTL;
> 	u_int16_t	HBTGTIRQCTL;
> 	u_int16_t	HBTGTIRQSTA;
> 	u_int16_t	HBMSTIRQCTL;
> 	u_int16_t	HBMSTIRQSTA;
> 	u_int8_t	pad_0x06a[0x2];
> 	u_int32_t	MSTINTADD;
> 
> 	/* System Arbitration */
> 	u_int8_t	SYSARBCTL;
> 	u_int8_t	PCIARBSTA;
> 	u_int16_t	SYSARBMENB;
> 	u_int32_t	ARBPRICTL;
> 	u_int8_t	pad_0x078[0x8];
> 
> 	/* System Address Mapping */
> 	u_int32_t	ADDDECCTL;
> 	u_int32_t	WPVSTA;
> 	u_int32_t	PAR0;
> 	u_int32_t	PAR1;
> 	u_int32_t	PAR2;
> 	u_int32_t	PAR3;
> 	u_int32_t	PAR4;
> 	u_int32_t	PAR5;
> 	u_int32_t	PAR6;
> 	u_int32_t	PAR7;
> 	u_int32_t	PAR8;
> 	u_int32_t	PAR9;
> 	u_int32_t	PAR10;
> 	u_int32_t	PAR11;
> 	u_int32_t	PAR12;
> 	u_int32_t	PAR13;
> 	u_int32_t	PAR14;
> 	u_int32_t	PAR15;
> 	u_int8_t	pad_0x0c8[0xb38];
> 
> 	/* GP Bus Controller */
> 	u_int8_t	GPECHO;
> 	u_int8_t	GPCSDW;
> 	u_int16_t	GPCSQUAL;
> 	u_int8_t	pad_0xc04[0x4];
> 	u_int8_t	GPCSRT;
> 	u_int8_t	GPCSPW;
> 	u_int8_t	GPCSOFF;
> 	u_int8_t	GPRDW;
> 	u_int8_t	GPRDOFF;
> 	u_int8_t	GPWRW;
> 	u_int8_t	GPWROFF;
> 	u_int8_t	GPALEW;
> 	u_int8_t	GPALEOFF;
> 	u_int8_t	pad_0xc11[0xf];
> 
> 	/* Programmable Input/Output */
> 	u_int16_t	PIOPFS15_0;
> 	u_int16_t	PIOPFS31_16;
> 	u_int8_t	CSPFS;
> 	u_int8_t	pad_0xc25;
> 	u_int8_t	CLKSEL;
> 	u_int8_t	pad_0xc27;
> 	u_int16_t	DSCTL;
> 	u_int16_t	PIODIR15_0;
> 	u_int16_t	PIODIR31_16;
> 	u_int8_t	 pad_0xc2e[0x2];
> 	u_int16_t	PIODATA15_0;
> 	u_int16_t	PIODATA31_16;
> 	u_int16_t	PIOSET15_0;
> 	u_int16_t	PIOSET31_16;
> 	u_int16_t	PIOCLR15_0;
> 	u_int16_t	PIOCLR31_16;
> 	u_int8_t	pad_0xc3c[0x24];
> 
> 	/* Software Timer */
> 	u_int16_t	SWTMRMILLI;
> 	u_int16_t	SWTMRMICRO;
> 	u_int8_t	SWTMRCFG;
> 	u_int8_t	pad_0xc65[0xb];
> 
> 	/* General-Purpose Timers */
> 	u_int8_t	GPTMRSTA;
> 	u_int8_t	pad_0xc71;
> 	u_int16_t	GPTMR0CTL;
> 	u_int16_t	GPTMR0CNT;
> 	u_int16_t	GPTMR0MAXCMPA;
> 	u_int16_t	GPTMR0MAXCMPB;
> 	u_int16_t	GPTMR1CTL;
> 	u_int16_t	GPTMR1CNT;
> 	u_int16_t	GPTMR1MAXCMPA;
> 	u_int16_t	GPTMR1MAXCMPB;
> 	u_int16_t	GPTMR2CTL;
> 	u_int16_t	GPTMR2CNT;
> 	u_int8_t	pad_0xc86[0x8];
> 	u_int16_t	GPTMR2MAXCMPA;
> 	u_int8_t	pad_0xc90[0x20];
> 
> 	/* Watchdog Timer */
> 	u_int16_t	WDTMRCTL;
> 	u_int16_t	WDTMRCNTL;
> 	u_int16_t	WDTMRCNTH;
> 	u_int8_t	pad_0xcb6[0xa];
> 
> 	/* UART Serial Ports */
> 	u_int8_t	UART1CTL;
> 	u_int8_t	UART1STA;
> 	u_int8_t	UART1FCRSHAD;
> 	u_int8_t	pad_0xcc3;
> 	u_int8_t	UART2CTL;
> 	u_int8_t	UART2STA;
> 	u_int8_t	UART2FCRSHAD;
> 	u_int8_t	pad_0xcc7[0x9];
> 
> 	/* Synchronous Serial Interface */
> 	u_int8_t	SSICTL;
> 	u_int8_t	SSIXMIT;
> 	u_int8_t	SSICMD;
> 	u_int8_t	SSISTA;
> 	u_int8_t	SSIRCV;
> 	u_int8_t	pad_0xcd5[0x2b];
> 
> 	/* Programmable Interrupt Controller */
> 	u_int8_t	PICICR;
> 	u_int8_t	pad_0xd01;
> 	u_int8_t	MPICMODE;
> 	u_int8_t	SL1PICMODE;
> 	u_int8_t	SL2PICMODE;
> 	u_int8_t	pad_0xd05[0x3];
> 	u_int16_t	SWINT16_1;
> 	u_int8_t	SWINT22_17;
> 	u_int8_t	pad_0xd0b[0x5];
> 	u_int16_t	INTPINPOL;
> 	u_int8_t	pad_0xd12[0x2];
> 	u_int16_t	PCIHOSTMAP;
> 	u_int8_t	pad_0xd16[0x2];
> 	u_int16_t	ECCMAP;
> 	u_int8_t	GPTMR0MAP;
> 	u_int8_t	GPTMR1MAP;
> 	u_int8_t	GPTMR2MAP;
> 	u_int8_t	pad_0xd1d[0x3];
> 	u_int8_t	PIT0MAP;
> 	u_int8_t	PIT1MAP;
> 	u_int8_t	PIT2MAP;
> 	u_int8_t	pad_0xd23[0x5];
> 	u_int8_t	UART1MAP;
> 	u_int8_t	UART2MAP;
> 	u_int8_t	pad_0xd2a[0x6];
> 	u_int8_t	PCIINTAMAP;
> 	u_int8_t	PCIINTBMAP;
> 	u_int8_t	PCIINTCMAP;
> 	u_int8_t	PCIINTDMAP;
> 	u_int8_t	pad_0xd34[0xc];
> 	u_int8_t	DMABCINTMAP;
> 	u_int8_t	SSIMAP;
> 	u_int8_t	WDTMAP;
> 	u_int8_t	RTCMAP;
> 	u_int8_t	WPVMAP;
> 	u_int8_t	ICEMAP;
> 	u_int8_t	FERRMAP;
> 	u_int8_t	pad_0xd47[0x9];
> 	u_int8_t	GP0IMAP;
> 	u_int8_t	GP1IMAP;
> 	u_int8_t	GP2IMAP;
> 	u_int8_t	GP3IMAP;
> 	u_int8_t	GP4IMAP;
> 	u_int8_t	GP5IMAP;
> 	u_int8_t	GP6IMAP;
> 	u_int8_t	GP7IMAP;
> 	u_int8_t	GP8IMAP;
> 	u_int8_t	GP9IMAP;
> 	u_int8_t	GP10IMAP;
> 	u_int8_t	pad_0xd5b[0x15];
> 
> 	/* Reset Generation */
> 	u_int8_t	SYSINFO;
> 	u_int8_t	pad_0xd71;
> 	u_int8_t	RESCFG;
> 	u_int8_t	pad_0xd73;
> 	u_int8_t	RESSTA;
> 	u_int8_t	pad_0xd75[0xb];
> 
> 	/* GP DMA Controller */
> 	u_int8_t	GPDMACTL;
> 	u_int8_t	GPDMAMMIO;
> 	u_int16_t	GPDMAEXTCHMAPA;
> 	u_int16_t	GPDMAEXTCHMAPB;
> 	u_int8_t	GPDMAEXTPG0;
> 	u_int8_t	GPDMAEXTPG1;
> 	u_int8_t	GPDMAEXTPG2;
> 	u_int8_t	GPDMAEXTPG3;
> 	u_int8_t	GPDMAEXTPG5;
> 	u_int8_t	GPDMAEXTPG6;
> 	u_int8_t	GPDMAEXTPG7;
> 	u_int8_t	pad_0xd8d[0x3];
> 	u_int8_t	GPDMAEXTTC3;
> 	u_int8_t	GPDMAEXTTC5;
> 	u_int8_t	GPDMAEXTTC6;
> 	u_int8_t	GPDMAEXTTC7;
> 	u_int8_t	pad_0xd94[0x4];
> 	u_int8_t	GPDMABCCTL;
> 	u_int8_t	GPDMABCSTA;
> 	u_int8_t	GPDMABSINTENB;
> 	u_int8_t	GPDMABCVAL;
> 	u_int8_t	pad_0xd9c[0x4];
> 	u_int16_t	GPDMANXTADDL3;
> 	u_int16_t	GPDMANXTADDH3;
> 	u_int16_t	GPDMANXTADDL5;
> 	u_int16_t	GPDMANXTADDH5;
> 	u_int16_t	GPDMANXTADDL6;
> 	u_int16_t	GPDMANXTADDH6;
> 	u_int16_t	GPDMANXTADDL7;
> 	u_int16_t	GPDMANXTADDH7;
> 	u_int16_t	GPDMANXTTCL3;
> 	u_int8_t	GPDMANXTTCH3;
> 	u_int8_t	pad_0xdb3;
> 	u_int16_t	GPDMANXTTCL5;
> 	u_int8_t	GPDMANXTTCH5;
> 	u_int8_t	pad_0xdb7;
> 	u_int16_t	GPDMANXTTCL6;
> 	u_int8_t	GPDMANXTTCH6;
> 	u_int8_t	pad_0xdbb;
> 	u_int16_t	GPDMANXTTCL7;
> 	u_int8_t	GPDMANXTTCH7;
> 	u_int8_t	pad_0xdc0[0x240];
> 	};
> 
> extern struct elan_mmcr *elan_mmcr;
> 
> -- 
> John Birrell




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?E1AWZBS-0002cO-2V>