From owner-freebsd-ppc@freebsd.org Wed Sep 21 18:15:49 2016 Return-Path: Delivered-To: freebsd-ppc@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 44C0EBE4DCA for ; Wed, 21 Sep 2016 18:15:49 +0000 (UTC) (envelope-from jau789@gmail.com) Received: from mail-lf0-x241.google.com (mail-lf0-x241.google.com [IPv6:2a00:1450:4010:c07::241]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (Client CN "smtp.gmail.com", Issuer "Google Internet Authority G2" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id BA0097A2 for ; Wed, 21 Sep 2016 18:15:48 +0000 (UTC) (envelope-from jau789@gmail.com) Received: by mail-lf0-x241.google.com with SMTP id s29so2842842lfg.3 for ; Wed, 21 Sep 2016 11:15:48 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-transfer-encoding; bh=zqOpRIbe3cZxGz/N+5a/35+ZwgJdis7jRB43GN6Netw=; b=CR+SdNdYoTwhqdbjuT5kM0tXaPwTuRvNVoPdCKO0ECJ3wurKfmQ/AcciSe85X+qEP2 NBYGaW7//qdEQwrXKHe0Fr7ys204Weqx47biS/Z+EoCe30DGqql5zYSvo5cgpK4wlVsR 9HrtFzVqAPJx6OuyFh82Y5Zsx5aBNw1B9j8fu0c+FGQnVQr6xnKNV4Fj9oYIHHveVbgX ESjcqRqBHnQAoxYtUSy5luKNprvEeQPaWhauHFsV5QOPfui5qnofjeZJ80qh4Vkm2Nwc RhSZD3/zJQq2YFGbYcIpNa1eaqgjkL1Z7ZWlWroHtGnjcoDUNkICposW5tjkhPCiDtt2 OApQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding; bh=zqOpRIbe3cZxGz/N+5a/35+ZwgJdis7jRB43GN6Netw=; b=ankLzDM1sp3jH9t+oFFl+Ty6ksxTMQdrHexfFRwhgROY9V02e3N8jgR0qm3Pi1hdOA zfB5CpW2SzKXvVW0cg7mND6nMcjV1RCzVc0NrHozQKxceSajEg9Z9o4mMxB2il8Jtt3D L1utgtlVPB4XvCrk3qtgexTA0OKpEz6DsFSb7I7LgIXMTPLDon6ZvfErzkE86MgAGwaV lsJPwO94HmS7eddWff3z6qOIBBf9dxTZ9d4KMZ0+kYuojBERKsmwKAy1UaFut64rDqB9 N0NuusP+Br8fNpr1fv4ODxu22NEjOEudBsj9tjjS26OMRmacU5j9fFiv3vVtrICccBWc 3rxA== X-Gm-Message-State: AE9vXwPOpOdzaCO7D0zd9gg4I7Dtvj2bFKPVPaT4e3kEofMAvRxOwJeRHpWVp8ZBPmf/CQ== X-Received: by 10.25.228.88 with SMTP id b85mr12669953lfh.175.1474481746846; Wed, 21 Sep 2016 11:15:46 -0700 (PDT) Received: from [192.168.1.131] (xdsl-205-1.nblnetworks.fi. [83.145.205.1]) by smtp.googlemail.com with ESMTPSA id g4sm6486410ljg.27.2016.09.21.11.15.45 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 21 Sep 2016 11:15:46 -0700 (PDT) Subject: Re: svn commit: r306065 - in head/sys vs. PowerMacs: Nathan's trail patch included but inappropriate? To: freebsd-ppc@freebsd.org, chmeeedalf@gmail.com References: <917EFF5A-D054-4424-9D7D-4E4BEF6072EF@gmail.com> From: "Jukka A. Ukkonen" Message-ID: <4bb1046a-225d-66b2-7b00-067f0d6f6c60@gmail.com> Date: Wed, 21 Sep 2016 21:15:42 +0300 User-Agent: Mozilla/5.0 (X11; FreeBSD amd64; rv:45.0) Gecko/20100101 Thunderbird/45.3.0 MIME-Version: 1.0 In-Reply-To: <917EFF5A-D054-4424-9D7D-4E4BEF6072EF@gmail.com> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 8bit X-BeenThere: freebsd-ppc@freebsd.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Porting FreeBSD to the PowerPC List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 21 Sep 2016 18:15:49 -0000 On 09/21/16 20:28, Justin Hibbits wrote: > On Sep 21, 2016, at 1:46 AM, Mark Millard wrote: > >> The following from >> >> https://lists.freebsd.org/pipermail/svn-src-head/2016-September/091934.html >> >> >> seems in include a patch that Nathan made for testing on >> PowerMac/iMac/Xserve G5's that failed the PowerMac7,3 test that was >> tried by Jukka A. Ukkonen. >> >>> Modified: head/sys/powerpc/ofw/ofw_machdep.c >>> ============================================================================== >>> >>> --- head/sys/powerpc/ofw/ofw_machdep.c Wed Sep 21 02:27:23 2016 >>> (r306064) >>> +++ head/sys/powerpc/ofw/ofw_machdep.c Wed Sep 21 02:28:39 2016 >>> (r306065) >>> @@ -99,6 +99,7 @@ ofw_restore_trap_vec(char *restore_trap_ >>> /* >>> * Saved SPRG0-3 from OpenFirmware. Will be restored prior to the >>> callback. >>> */ >>> +#ifndef __powerpc64__ >>> register_t ofw_sprg0_save; >>> >>> static __inline void >>> @@ -140,6 +141,8 @@ ofw_sprg_restore(void) >>> } >>> #endif >>> >>> +#endif >>> + >>> static int >>> parse_ofw_memory(phandle_t node, const char *prop, struct mem_region >>> *output) >>> { >>> @@ -344,11 +347,12 @@ OF_initial_setup(void *fdt_ptr, void *ju >>> ofmsr[0] = mfmsr(); >>> #ifdef __powerpc64__ >>> ofmsr[0] &= ~PSL_SF; >>> - #endif >>> + #else >>> __asm __volatile("mfsprg0 %0" : "=&r"(ofmsr[1])); >>> __asm __volatile("mfsprg1 %0" : "=&r"(ofmsr[2])); >>> __asm __volatile("mfsprg2 %0" : "=&r"(ofmsr[3])); >>> __asm __volatile("mfsprg3 %0" : "=&r"(ofmsr[4])); >>> + #endif >>> openfirmware_entry = openfirm; >>> >>> if (ofmsr[0] & PSL_DR) >>> @@ -440,7 +444,9 @@ openfirmware_core(void *args) >>> */ >>> oldmsr = intr_disable(); >>> >>> +#ifndef __powerpc64__ >>> ofw_sprg_prepare(); >>> +#endif >>> >>> /* Save trap vectors */ >>> ofw_save_trap_vec(save_trap_of); >>> @@ -463,7 +469,9 @@ openfirmware_core(void *args) >>> /* Restore trap vecotrs */ >>> ofw_restore_trap_vec(save_trap_of); >>> >>> +#ifndef __powerpc64__ >>> ofw_sprg_restore(); >>> +#endif >>> >>> intr_restore(oldmsr); >> >> Part of the ofw_sprg_prepare() and ofw_sprg_restore() activity is >> required for PowerMac G5's to boot: the save of the FreeBSD sprg0 >> value and its later restore back to sprg0. (Established by other >> testing after Nathan's patch was tried.) >> >> My guess is that this code was accidentally included in -r306065, not >> intentionally included. >> >> >> [There is the separate issue that avoiding restoring the Open Firmware >> sprg0 value before calling into Open Firmware (leaving the FreeBSD >> value in place) helps PowerMac G5's boot more reliably by allowing >> correct handling some SLB faults that sometimes occur.] >> >> === >> Mark Millard >> markmi at dsl-only.net >> > > Crap, I got extra stuff in my diff. Going to revert this part tonight, > until everything is known good. > > - Justin > _______________________________________________ > freebsd-ppc@freebsd.org mailing list > https://lists.freebsd.org/mailman/listinfo/freebsd-ppc > To unsubscribe, send any mail to "freebsd-ppc-unsubscribe@freebsd.org" The least that will have to be changed to make the code boot on PowerMac G5 is to change the following ... __asm __volatile("mfsprg0 %0\n\t" "mtsprg0 %1\n\t" "mtsprg1 %2\n\t" "mtsprg2 %3\n\t" "mtsprg3 %4\n\t" : "=&r"(ofw_sprg0_save) : "r"(ofmsr[1]), "r"(ofmsr[2]), "r"(ofmsr[3]), "r"(ofmsr[4])); in function ofw_sprg_prepare() in sys/powerpc/ofw/ofw_machdep.c to this ... __asm __volatile("mfsprg0 %0\n\t" "mtsprg1 %1\n\t" "mtsprg2 %2\n\t" "mtsprg3 %3\n\t" : "=&r"(ofw_sprg0_save) : "r"(ofmsr[2]), "r"(ofmsr[3]), "r"(ofmsr[4])); This only removes "mtsprg0" and its corresponding parameter. Alternatively one could use the absolutely minimalistic ... __asm __volatile("mfsprg0 %0\n\t" : "=&r"(ofw_sprg0_save) : ); on a G5. I have been running exactly this since my testing sessions with no ill effects at all. The downside is that nobody has tested this minimalistic approach on any other ppc variant but my G5. I have had a pending plan to test the same approach on my 32-bit G4, but the task being somewhat time consuming it is still pending. ;-) Anyhow the old code will not boot on a G5 without a change, neither will it boot with Nathan's patch included. Releasing 11.0-stable in a state that will not actually boot on one of the supported platforms will not look awfully bright either. I guess this is an issue for the re team to decide. --jau