From owner-svn-src-projects@FreeBSD.ORG Wed Jul 29 22:19:52 2009 Return-Path: Delivered-To: svn-src-projects@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 6DD8B106566B; Wed, 29 Jul 2009 22:19:52 +0000 (UTC) (envelope-from nwhitehorn@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:4f8:fff6::2c]) by mx1.freebsd.org (Postfix) with ESMTP id 5BEEE8FC12; Wed, 29 Jul 2009 22:19:52 +0000 (UTC) (envelope-from nwhitehorn@FreeBSD.org) Received: from svn.freebsd.org (localhost [127.0.0.1]) by svn.freebsd.org (8.14.3/8.14.3) with ESMTP id n6TMJqdt083994; Wed, 29 Jul 2009 22:19:52 GMT (envelope-from nwhitehorn@svn.freebsd.org) Received: (from nwhitehorn@localhost) by svn.freebsd.org (8.14.3/8.14.3/Submit) id n6TMJq0J083991; Wed, 29 Jul 2009 22:19:52 GMT (envelope-from nwhitehorn@svn.freebsd.org) Message-Id: <200907292219.n6TMJq0J083991@svn.freebsd.org> From: Nathan Whitehorn Date: Wed, 29 Jul 2009 22:19:52 +0000 (UTC) To: src-committers@freebsd.org, svn-src-projects@freebsd.org X-SVN-Group: projects MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Cc: Subject: svn commit: r195956 - in projects/ppc64/sys/powerpc: aim include X-BeenThere: svn-src-projects@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: "SVN commit messages for the src " projects" tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 29 Jul 2009 22:19:52 -0000 Author: nwhitehorn Date: Wed Jul 29 22:19:52 2009 New Revision: 195956 URL: http://svn.freebsd.org/changeset/base/195956 Log: Make 32-bit kernels operational again by not storing DAR and R31 in the same part of the register cache for traps, and by dealing with some stupidity in the way Apple stores the available physical memory list in firmware. Modified: projects/ppc64/sys/powerpc/aim/ofw_machdep.c projects/ppc64/sys/powerpc/include/pcpu.h Modified: projects/ppc64/sys/powerpc/aim/ofw_machdep.c ============================================================================== --- projects/ppc64/sys/powerpc/aim/ofw_machdep.c Wed Jul 29 22:02:13 2009 (r195955) +++ projects/ppc64/sys/powerpc/aim/ofw_machdep.c Wed Jul 29 22:19:52 2009 (r195956) @@ -145,8 +145,11 @@ parse_ofw_memory(phandle_t node, const c { cell_t address_cells, size_cells; int sz, i, j; + int apple_hack_mode; phandle_t phandle; + sz = 0; + apple_hack_mode = 0; /* * Get #address-cells from root node, defaulting to 1 if it cannot @@ -159,7 +162,20 @@ parse_ofw_memory(phandle_t node, const c if (OF_getprop(phandle, "#size-cells", &size_cells, sizeof(size_cells)) < sizeof(size_cells)) size_cells = 1; + + /* + * On Apple hardware, address_cells is always 1 for "available", + * even when it is explicitly set to 2. Then all memory above 4 GB + * should be added by hand to the available list. Detect Apple hardware + * by seeing if ofw_real_mode is set -- only Apple seems to use + * virtual-mode OF. + */ + if (strcmp(prop, "available") == 0 && !ofw_real_mode) + apple_hack_mode = 1; + if (apple_hack_mode) + address_cells = 1; + /* * Get memory. */ @@ -217,6 +233,25 @@ parse_ofw_memory(phandle_t node, const c panic("Physical memory map not found"); } + #ifdef __powerpc64__ + if (apple_hack_mode) { + /* Add in regions above 4 GB to the available list */ + struct mem_region himem[OFMEM_REGIONS]; + int hisz; + + hisz = parse_ofw_memory(node, "reg", himem); + j = sz/sizeof(output[0]); + for (i = 0; i < hisz/sizeof(himem[0]); i++) { + if (himem[i].mr_start > BUS_SPACE_MAXADDR_32BIT) { + output[j].mr_start = himem[i].mr_start; + output[j].mr_size = himem[i].mr_size; + j++; + } + } + sz = j*sizeof(output[0]); + } + #endif + return (sz); } Modified: projects/ppc64/sys/powerpc/include/pcpu.h ============================================================================== --- projects/ppc64/sys/powerpc/include/pcpu.h Wed Jul 29 22:02:13 2009 (r195955) +++ projects/ppc64/sys/powerpc/include/pcpu.h Wed Jul 29 22:19:52 2009 (r195956) @@ -71,12 +71,12 @@ struct pmap; #define CPUSAVE_R29 2 /* where r29 gets saved */ #define CPUSAVE_R30 3 /* where r30 gets saved */ #define CPUSAVE_R31 4 /* where r31 gets saved */ -#define CPUSAVE_AIM_DAR 4 /* where SPR_DAR gets saved */ -#define CPUSAVE_AIM_DSISR 5 /* where SPR_DSISR gets saved */ -#define CPUSAVE_BOOKE_DEAR 4 /* where SPR_DEAR gets saved */ -#define CPUSAVE_BOOKE_ESR 5 /* where SPR_ESR gets saved */ -#define CPUSAVE_SRR0 6 /* where SRR0 gets saved */ -#define CPUSAVE_SRR1 7 /* where SRR1 gets saved */ +#define CPUSAVE_AIM_DAR 5 /* where SPR_DAR gets saved */ +#define CPUSAVE_AIM_DSISR 6 /* where SPR_DSISR gets saved */ +#define CPUSAVE_BOOKE_DEAR 5 /* where SPR_DEAR gets saved */ +#define CPUSAVE_BOOKE_ESR 6 /* where SPR_ESR gets saved */ +#define CPUSAVE_SRR0 7 /* where SRR0 gets saved */ +#define CPUSAVE_SRR1 8 /* where SRR1 gets saved */ /* Book-E TLBSAVE is more elaborate */ #define TLBSAVE_BOOKE_LR 0