View previous topic :: View next topic |
Author |
Message |
dusxmt n00b
Joined: 18 Jun 2018 Posts: 4
|
Posted: Mon Jun 18, 2018 4:09 pm Post subject: A guide to installing GRUB on NewWorld PowerMacs |
|
|
Greetings. Since there doesn't seem to be any sort of step-by-step guide for setting up grub on PowerPC, and because I've had problems with building Yaboot, I've decided to have a go at writing it.
There's two ways of setting up grub, either semi-automatically using grub-install, or manually using grub-mkimage[1]. In both cases, a bootstrap partition that can be read by openfirmware is needed, with the default (and minimum) 800K bootstrap partition being sufficient.
Preparation:
Before we can begin, we need to install grub. It's currently masked, so unmasking is necessary:
Code: | # echo '=sys-boot/grub-2.02-r1 **' > /etc/portage/package.accept_keywords/grub |
Next, we need to make sure support for the powerpc-ieee1275 (OpenFirmware on PowerPC) platform is built:
Code: | # echo 'GRUB_PLATFORMS="ieee1275"' >> /etc/portage/make.conf |
After this, grub can be installed:
Code: | # emerge --ask sys-boot/grub |
Additionally, hfsutils are needed for setting up the bootstrap partition:
Code: | # emerge --ask sys-fs/hfsutils |
A) Semi-automatic installation:
grub-install uses the native filesystem drivers to install the boot image, so make sure you have support for hfs available in your kernel.
The first step is setting up the bootstrap partition, be sure to replace sdX with the device node of your bootstrap partition:
Code: | # dd if=/dev/zero of=/dev/sdX bs=512
# hformat -l bootstrap /dev/sdX |
Now that the partition is formatted, we can mount it and install grub:
Code: | # mkdir /tmp/bootstrap
# mount -t hfs /dev/sdX /tmp/bootstrap
# grub-install --macppc-directory=/tmp/bootstrap
# umount /tmp/bootstrap |
If you take a look at the created directory tree in /tmp/bootstrap, you'll see that (the current version of) grub mimics the filesystem layout of OSX, this is presumably for extra compatibility with external tools. However, what it doesn't seem to do is set up the file type for the boot script and it doesn't bless the folder which contains it, this can be corrected with the following set of commands:
Code: | # hmount /dev/sdX
# hattrib -t tbxi -c UNIX :System:Library:CoreServices:BootX
# hattrib -b :System:Library:CoreServices
# humount |
It should now be possible to launch grub with the default "boot hd:,\\:tbxi" command on the open firmware prompt, or perhaps "boot hd:number,\\:tbxi" if you have other bootable partitions that precede the bootstrap partition, or "boot hd:number,\System\Library\CoreServices\BootX" in case open firmware doesn't for some reason detect the medium as bootable.
The next step is configuring grub using the standard means:
Code: | # vi /etc/default/grub
# grub-mkconfig --output=/boot/grub/grub.cfg |
After this, reboot, and hope for the best
B) Manual installation:
In case you're having trouble with the semi-automatic installation, or would like to have more fine-grained control over the installation process, you can install grub manually[1].
The first step is to install grub's modules and to set up a preliminary configuration file in the /boot directory:
Code: | # mkdir -p /boot/grub/powerpc-ieee1275
# cp /usr/lib/grub/powerpc-ieee1275/{*.mod,*.lst} /boot/grub/powerpc-ieee1275/ |
Code: | # vi /boot/grub/grub.cfg
insmod linux
menuentry "Gentoo GNU/Linux" {
echo 'Loading the kernel...'
linux /boot/vmlinux root=UUID=<UUID> rootfstype=ext4 ro
echo 'Loading the initial ram disk...'
initrd /boot/initrd
} |
Replace <UUID> with the UUID of your root partition, and If you have an explicit boot partition, remove the "/boot" prefix from the paths in the above configuration. If you don't use an initrd, remove the two lines that deal with it as well. And of course, if you use a different root filesystem than ext4, edit the rootfstype= option as well.
Next, we need a built-in configuration file that will be physically baked into the bootable grub image:
Code: | # vi grub.cfg.atom
echo 'Looking for the boot partition...'
search --no-floppy --fs-uuid --set=root <UUID>
set prefix=($root)/boot/grub
echo 'Loading configuration...'
insmod configfile
configfile /boot/grub/grub.cfg |
Now replace <UUID> with the UUID of your boot partition, and again, if you have an explicit boot partition instead of it being a folder in your root partition, delete the "/boot" prefix from the paths.
The next step is to create a file with the list of modules you want to build into the image, in my case it is:
Code: | # vi modules.list
search_fs_uuid.mod search_fs_file.mod search_label.mod search.mod
part_apple.mod
fshelp.mod ext2.mod
halt.mod reboot.mod echo.mod |
Make sure that the module for the file system of your boot partition is in this list. Additionally, if you're using LVM or LDM, you might need the "lvm.mod" and "ldm.mod" modules, for RAID you may need "diskfilter.mod" "raid5rec.mod" "raid6rec.mod", for an encrypted boot you may need the appropriate crypto modules and to add an invocation of "cryptomount -u <drive>" to your config. See util/grub-install.c (in particular, invocations of grub_install_push_module ()).
You can find dependency information for the modules in the file /usr/lib/grub/powerpc-ieee1275/moddep.lst
With the list of modules ready, you can now generate a bootable image of grub:
Code: | # grub-mkimage --prefix=/boot/grub --format=powerpc-ieee1275 --config=grub.cfg.atom --output=grub.img `cat modules.list` |
Next off, we need to format the bootstrap partition and copy the created image onto it, be sure to replace sdX with the device node of your bootstrap partition:
Code: | # dd if=/dev/zero of=/dev/sdX bs=512
# hformat -l bootstrap /dev/sdX
# hmount /dev/sdX
# hcopy -r grub.img :grub.img |
It should now be possible to boot grub with an explicit invocation of "boot hd:number,\grub.img". If you would like grub to be bootable using the default "boot hd:,\\:tbxi" command, a boot script is needed, here's an example[2] of one that just boots grub:
Code: | # vi ofboot.b
<CHRP-BOOT>
<COMPATIBLE>
MacRISC MacRISC3 MacRISC4
</COMPATIBLE>
<DESCRIPTION>
grub
</DESCRIPTION>
<BOOT-SCRIPT>
boot &device;:&partition;,\grub.img
</BOOT-SCRIPT>
</CHRP-BOOT> |
Now we need to copy this script onto the bootstrap partition, mark it as being of the type tbxi (which stands for "Toolbox Image", referring to the Macintosh Toolbox), and to bless the root directory.
Code: | # hcopy -r ofboot.b :ofboot.b
# hattrib -t tbxi -c UNIX :ofboot.b
# hattrib -b : |
I found that on my machine (a Titanium PowerBook G4), there need to be at least 3 files in the blessed directory for it to work, so we'll copy the modules.list file as well:
Code: | # hcopy -r modules.list :modules.list |
We can now unmount the bootstrap partition, and try to reboot and see if it works:
It should now be possible to launch grub with the default "boot hd:,\\:tbxi" command on the open firmware prompt, or perhaps "boot hd:number,\\:tbxi" if you have other bootable partitions that precede the bootstrap partition, or "boot hd:number,\grub.img" in case open firmware doesn't for some reason detect the medium as bootable.
Graphical console for the manual installation:
The default look of grub on open firmware (with the manual method, at least) is pretty crummy, but thankfully, there is a framebuffer driver for the open firmware framebuffer in grub, and it's pretty easy to enable.
First thing's first, we need to install a graphical font:
Code: | # cp /usr/share/grub/unicode.pf2 /boot/grub/ |
Now we can configure grub accordingly:
Code: | # vi /boot/grub/grub.cfg
insmod ieee1275_fb
insmod gfxterm
loadfont ${prefix}/unicode.pf2
set gfxmode=auto
terminal_output gfxterm
insmod linux
menuentry "Gentoo GNU/Linux" {
echo 'Loading the kernel...'
linux /boot/vmlinux root=UUID=<UUID> rootfstype=ext4 ro
echo 'Loading the initial ram disk...'
initrd /boot/initrd
} |
This config is the same as the initial one, but with some extra code at the beginning.
If everything worked as it should, you should now have a pretty nice-looking boot-up screen with grub
Sources:
1 - http://cynic.cc/blog/posts/running_grub2_on_powerpc_macs
2 - https://lists.debian.org/debian-powerpc/2005/10/msg00074.html
3 - http://git.savannah.gnu.org/cgit/grub.git/tree/util/grub-install.c
Other articles worth reading:
http://mac.linux.be/content/guide-open-firmware-apple-bios-0
https://www.netbsd.org/ports/macppc/faq.html
http://ftp.netbsd.org/pub/NetBSD/NetBSD-7.1.2/macppc/INSTALL.html#Open%20Firmware%20boot%20syntax _________________ GNU is as new as gold is old. |
|
Back to top |
|
|
cloverskull n00b
Joined: 03 Nov 2017 Posts: 5
|
Posted: Fri Jun 22, 2018 11:02 pm Post subject: |
|
|
Thanks for this write-up! I was able to get grub to work, using the automatic configuration. However, I hit a bit of a snag when I tried launching xorg. It seems likely to be some sort of modesetting or framebuffer issue.
My working yaboot config looks like this:
Code: | boot=/dev/hda2
device=hd:
partition=4
root=/dev/hda4
timeout=30
install=/usr/lib/yaboot/yaboot
magicboot=/usr/lib/yaboot/ofboot
image=/boot/kernel-4.9.72-gentoo
label=Linux
read-only
append="video=ofonly rootfstype=ext4"
initrd=/boot/initramfs-genkernel-ppc-4.9.72-gentoo
initrd-size=8192
|
I tried manually adding the "video=ofonly" argument in the grub configuration, but it didn't work; I still had xorg problems. Any ideas what might be going wrong here?[/code] |
|
Back to top |
|
|
dusxmt n00b
Joined: 18 Jun 2018 Posts: 4
|
Posted: Sat Jun 23, 2018 6:11 am Post subject: |
|
|
Hmmm... I know GRUB messes with the vga= option on PCs, but I didn't think it messed with video= ... perhaps gfxpayload might be the culprit.
I'd double check that the option actually gets passed to the kernel:
Code: | $ cat /proc/cmdline |
and also doble check that you added the option to the right field (GRUB_CMDLINE_LINUX) of /etc/default/grub and re-generated the config in /boot/grub/grub.cfg afterwards, making sure to check whether it is there. _________________ GNU is as new as gold is old. |
|
Back to top |
|
|
cloverskull n00b
Joined: 03 Nov 2017 Posts: 5
|
Posted: Sat Jun 23, 2018 10:26 pm Post subject: |
|
|
Thanks for the help. I checked /proc/cmdline and can confirm it's getting passed. I also put it in the correct spot in /etc/default/grub and confirmed in /boot/grub/grub.cfg. I also added the gfxpayload=text option this time, and have the same issues. Bummer. |
|
Back to top |
|
|
dusxmt n00b
Joined: 18 Jun 2018 Posts: 4
|
Posted: Sun Jun 24, 2018 8:27 am Post subject: |
|
|
Since it's getting passed to the kernel, I suspect that grub's also passing some other options to the video driver that then make it fail with X; I'd try explicitly setting the video options, eg. on my machine I pass radeonfb.mode_option=1152x768-32 _________________ GNU is as new as gold is old. |
|
Back to top |
|
|
giordanogalli n00b
Joined: 26 Jul 2019 Posts: 1
|
Posted: Fri Jul 26, 2019 9:18 am Post subject: |
|
|
Hello dusxmt
Since I'm a OSX user trying to switch to Linux, you will hopefully pardon me for asking such a dumb question: is the command line shown in your message the one from OSX?
Thank you for your help.
Giordano |
|
Back to top |
|
|
dusxmt n00b
Joined: 18 Jun 2018 Posts: 4
|
Posted: Sun Jul 28, 2019 9:41 am Post subject: |
|
|
Hello, giordanogalli
No, the commands are all for Gentoo, the guide assumes you already have a Gentoo system deployed (from a stage3 archive) and chrooted into (from a Live CD)
, installing the bootloader is a part of the installation procedure from a Live CD.
Also, while I share your enthusiasm for RISC and PowerPC hardware, I think that for learning to use GNU/Linux, it might be better to first start with something more widely supported (Like a Raspberry Pi), as I think it would be a shame if the many stumbling blocks that using obscure hardware unfortunately brings would discourage you from the system.
Also Adelie might be an interesting distro to check out, they support PowerPC as a tier-1 platform, and unlike Gentoo, you don't have to compile everything yourself and wait hours upon hours for things to get set up. _________________ GNU is as new as gold is old. |
|
Back to top |
|
|
mattst88 Developer
Joined: 28 Oct 2004 Posts: 422
|
Posted: Fri Aug 09, 2019 10:15 pm Post subject: |
|
|
Thanks! This was incredibly useful! Using your instructions I have my iMac G4 booting grub via the automatic method.
I plan to write some changes for the Gentoo handbook and then see if we can remove yaboot |
|
Back to top |
|
|
xplosivelugnut n00b
Joined: 03 Apr 2015 Posts: 9
|
Posted: Thu Feb 25, 2021 4:33 am Post subject: |
|
|
Just confirming that this works flawlessly on a GPT drive in a 2005 G5.
Thanks! |
|
Back to top |
|
|
Atha Apprentice
Joined: 22 Sep 2004 Posts: 230
|
Posted: Sun Apr 25, 2021 9:06 am Post subject: |
|
|
Hi!
xplosivelugnut wrote: | Just confirming that this works flawlessly on a GPT drive in a 2005 G5. |
How does this work? How do you "bless" the bootloader on a GPT partition for PowerPC? Is a special boot partition required, possibly a hybrid (aka MBR) FAT partition? _________________ Think for yourself and let others enjoy the privilege of doing so too. – Voltaire |
|
Back to top |
|
|
xplosivelugnut n00b
Joined: 03 Apr 2015 Posts: 9
|
Posted: Tue Apr 27, 2021 3:33 am Post subject: |
|
|
The late 2005 PCIe G5's natively support GPT.
So all you need is a "bootstrap" partition with an elf in the right place with the tbxi attribute and you're good to go.
In my case, I used GPT fdisk and created a 128 MB "bootstrap" partition as the first partition. Another 128 MB partition for the /boot partition. And the rest of the disk for the / (root) partition. Vaguely EFI-esque. All the partition types were just left as 8300.
I then formatted the bootstrap partition with HFS and mounted it to /boot/bootstrap.
grub-install takes care of the rest.
Code: | # dd if=/dev/zero of=/dev/sdXn bs=512
# hformat -l bootstrap /dev/sdXn
# mount /dev/sdXn /boot/bootstrap/
# grub-install --macppc-directory=/boot/bootstrap
|
This created the following directory structure and files in /boot/bootstrap/ (sdXn)
Code: | /
mach_kernel
System/
Library/
CoreServices/
.disk_label
.disk_label.contentDetails
BootX
grub.elf
SystemVersion.plist
|
And I don't know if this next part was necessary. For all I know, grub-install handled this too.
Code: | # umount /boot/bootstrap/
# hmount /dev/sdXn
# hattrib -t tbxi -c UNIX :System:Library:CoreServices:BootX
# hattrib -b :System:Library:CoreServices
# humount
|
Grub then shows up as a boot option if I boot the G5 holding the Option key. It would probably boot by default if I didn't have an OSX install on the first SATA drive.
As far as I know, only the PCIe G5's from '05 can do this. You can also copy an OSX install to a GPT drive and it works just fine. The OSX install disk I have won't let a PPC machine install it straight to a GPT drive though. Wonder if there's one that will? |
|
Back to top |
|
|
Atha Apprentice
Joined: 22 Sep 2004 Posts: 230
|
Posted: Fri May 14, 2021 3:22 pm Post subject: |
|
|
xplosivelugnut wrote: | The late 2005 PCIe G5's natively support GPT. |
Wow! I did not know that. Since the Late-2005-G5s don't support anything earlier than 10.4 anyhow, that should work. Tiger is officially booting off of GPT, so I think it would be worth a try to setup multi-boot with Mac OS X and Linux.
As you correctly pointed out Mac OS X won't install onto a GPT partition on a PowerPC-based Mac, but it is possible to use something like Disk Utility's backup and restore funktion to get it onto such a partition. It would require to install it onto a second HDD first, or onto an external drive's partition. Then clone that installation into an disk image, boot that installation from the external drive and use it to restore the disk image to the interal GPT drive. IMHO it's best practice to clone a non-active operating system, not one that is in use – hence the intermediate step to create a disk image first.
As an alternative to Disk Utility an older Carbon Copy Cloner version (shareware) will also do the job. It's what I used to test if OS X Lion (version 10.7, Intel-only) was able to boot from an MBR partition on an Intel Mac. It worked. Mac OS X can boot from anything it knows, even when it doesn't support it as installation destination. Therefore, if the firmware supports it, Mac OS X can be booted on MBR, APM and (starting with Tiger) GPT.
Now that I know that, I will certainly try GPT on my own Late-2005 Power Mac. The only drawback I see right now is that the Apple Hardware Test, which I have cloned from the original DVD onto the internal HDD (using the same partition type) will most likely not function from GPT. _________________ Think for yourself and let others enjoy the privilege of doing so too. – Voltaire |
|
Back to top |
|
|
kahuna n00b
Joined: 21 Apr 2022 Posts: 10 Location: Alberta, Canada
|
Posted: Thu Apr 21, 2022 4:30 am Post subject: |
|
|
I know it's been years, but thanks for the quick guide dusxmt.
The automated GRUB install worked like a charm on my G5. You don't need to unmask it anymore
Just one note worth to mention, at least for G5s... a Kernel created by 'genkernel' does not work, you get a "invalid memory access" message on boot.
Apparently, a Kernel configured as make g5_defconfig does work. I'm compiling it as I type this.
https://forums.gentoo.org/viewtopic-t-1128505.html |
|
Back to top |
|
|
min.xu n00b
Joined: 11 Jun 2022 Posts: 2
|
Posted: Sat Jun 11, 2022 6:46 pm Post subject: |
|
|
Quote: | Just one note worth to mention, at least for G5s... a Kernel created by 'genkernel' does not work, you get a "invalid memory access" message on boot. |
I am on a powerbook g4 and ran into the same issue. It seems related to kernel config's KERNEL_START or PHYSICAL_START settings. (Also, trying to load ppc64 kernel from the livecd/usb also resulted in similar error msg.
I ran Code: | genkernel --menuconfig all | and load the CDROM/USB's ppc32-config file and saved it back .config. After that, genkernel was able to build a working ppc32 kernel for me. |
|
Back to top |
|
|
kahuna n00b
Joined: 21 Apr 2022 Posts: 10 Location: Alberta, Canada
|
Posted: Thu Jun 16, 2022 4:42 am Post subject: |
|
|
min.xu wrote: |
I ran Code: | genkernel --menuconfig all | and load the CDROM/USB's ppc32-config file and saved it back .config. After that, genkernel was able to build a working ppc32 kernel for me. |
I'm glad that you found a way, it's good to know.
I ended up configuring my own Kernel, it does take more time for sure... |
|
Back to top |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
|