mirror of
https://git.proxmox.com/git/grub2
synced 2025-10-05 00:43:27 +00:00

VSX bit is enabled by default for Power7 and Power8 CPU models, so we need to disable them in order to avoid instruction exceptions. Kernel will activate it when necessary. * grub-core/kern/powerpc/ieee1275/startup.S: Disable VSX. Also-By: Adhemerval Zanella <azanella@linux.vnet.ibm.com> Also-By: Colin Watson <cjwatson@debian.org> Origin: other, https://lists.gnu.org/archive/html/grub-devel/2014-09/msg00078.html Last-Update: 2015-01-27 Patch-Name: ppc64el-disable-vsx.patch
80 lines
1.9 KiB
ArmAsm
80 lines
1.9 KiB
ArmAsm
/* startup.S - Startup code for the PowerPC. */
|
|
/*
|
|
* GRUB -- GRand Unified Bootloader
|
|
* Copyright (C) 2003,2004,2005,2007,2008 Free Software Foundation, Inc.
|
|
*
|
|
* GRUB is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* GRUB is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with GRUB. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include <grub/symbol.h>
|
|
#include <grub/offsets.h>
|
|
|
|
#define MSR_VSX 0x80
|
|
|
|
.extern __bss_start
|
|
.extern _end
|
|
|
|
.text
|
|
.align 2
|
|
.globl start, _start
|
|
start:
|
|
_start:
|
|
_start:
|
|
|
|
/* Disable VSX instruction */
|
|
mfmsr 0
|
|
oris 0,0,MSR_VSX
|
|
/* The "VSX Available" bit is in the lower half of the MSR, so we
|
|
don't need mtmsrd, which in any case won't work in 32-bit mode. */
|
|
mtmsr 0
|
|
isync
|
|
|
|
li 2, 0
|
|
li 13, 0
|
|
|
|
/* Stage1 won't zero BSS for us. In other cases, why not do it again? */
|
|
lis 6, (__bss_start - 4)@h
|
|
ori 6, 6, (__bss_start - 4)@l
|
|
|
|
2: stb 2, 4(6)
|
|
addi 6, 6, 1
|
|
andi. 7, 6, 3
|
|
cmpi 0, 1, 7, 0
|
|
bne 2b
|
|
|
|
lis 7, (_end - 4)@h
|
|
ori 7, 7, (_end - 4)@l
|
|
subf 7, 6, 7
|
|
subi 8, 7, 1
|
|
andi. 8, 8, 3
|
|
addi 8, 8, 1
|
|
sub 7, 7, 8
|
|
|
|
srwi 7, 7, 2 /* We store 4 bytes at a time. */
|
|
mtctr 7
|
|
2: stwu 2, 4(6) /* We know r2 is already 0 from above. */
|
|
bdnz 2b
|
|
|
|
mtctr 8
|
|
2: stb 2, 4(6) /* We know r2 is already 0 from above. */
|
|
addi 6, 6, 1
|
|
bdnz 2b
|
|
|
|
/* Store r5 in grub_ieee1275_entry_fn. */
|
|
lis 9, grub_ieee1275_entry_fn@ha
|
|
stw 5, grub_ieee1275_entry_fn@l(9)
|
|
|
|
bl grub_main
|
|
1: b 1b
|