Fedora Sorcerer (Le4d) Mac OS
SDLTRS - a TRS-80 Emulator for Mac OS X, Windows, and Linux sdltrs is a Radio Shack TRS-80 Model I/III/4/4P emulator for Macintosh OSX, Windows, and Linux. It has been ported from Tim Mann's excellent X-Windows UNIX emulator xtrs. Jiusion 40 to 1000x Magnification Endoscope, 8 LED USB 2.0 Digital Microscope, Mini Camera with OTG Adapter and Metal Stand, Compatible with Mac Window 7 8 10 Android Linux. The Raspberry Pi is a tiny and affordable computer that you can use to learn programming through fun, practical projects. Join the global Raspberry Pi community.
08 August 2013 Karim ElatovI was using my new Mac and there are just something that I missed from my previous Linux Laptops. So I decided to install Fedora on my new MacBook Pro :). The biggest challenge is getting around the EUFI interface.
BIOS VS EUFI
Is the link where you will find eveything. The following two methods both place all of the files in the /usr/local/bin directory in the hard driver. Unfortunately that directory is not in the default path. That means that when you type avrdude into the terminal it cant figure out where to look. In this prep-step you'll change the profile of your Terminal to add /usr/local/bin to the path. Find the Terminal program, you'll be using.
The Arch Page entitled “Unified Extensible Firmware Interface” has a good summary and helped me out during the preparation of the install:
Unified Extensible Firmware Interface (or UEFI for short) is a new type of firmware that was initially designed by Intel (known as EFI then) mainly for its Itanium based systems. It introduces new ways of booting an OS that is distinct from the commonly used “MBR boot code” method followed for BIOS systems.
Booting an OS using BIOSA BIOS or Basic Input-Output System is the very first program that is executed once the system is switched on. After all the hardware has been initialized and the POST operation has completed, the BIOS executes the first boot code in the first device in the device booting list.
If the list starts with a CD/DVD drive, then the El-Torito entry in the CD/DVD is executed. This is how bootable CD/DVD works. If the list starts with a HDD, then BIOS executes the very first 440 bytes MBR boot code. The boot code then chainloads or bootstraps a much larger and complex bootloader which then loads the OS.
Basically, the BIOS does not know how to read a partition table or filesystem. All it does is initialize the hardware, then load and run the 440-byte boot code.
Multiboot on BIOSSince very little can be achieved by a program that fits into the 440-byte boot code area, multi-booting using BIOS requires a multi-boot capable bootloader (multi-boot refers to booting multiple operating systems, not to booting a kernel in the Multiboot format specified by the GRUB developers). So usually a common bootloader like GRUB or Syslinux or LILO would be loaded by the BIOS, and it would load an operating system by either chain-loading or directly loading the kernel.
Booting an OS using UEFIUEFI firmware does not support booting through the above mentioned method which is the only way supported by BIOS. UEFI has support for reading both the partition table as well as understanding filesystems.
The commonly used UEFI firmwares support both MBR and GPT partition table. EFI in Apple-Intel Macs are known to also support Apple Partition Map besides MBR and GPT. Most UEFI firmwares have support for accessing FAT12 (floppy disks), FAT16 and FAT32 filesystems in HDDs and ISO9660 (and UDF) in CD/DVDs. EFI in Apple-Intel Macs can access HFS/HFS+ filesystems also apart from the mentioned ones.
UEFI does not launch any boot code in the MBR whether it exists or not. Instead it uses a special partition in the partition table called EFI SYSTEM PARTITION in which files required to be launched by the firmware are stored. Each vendor can store its files under <EFI SYSTEM PARTITION>/EFI/<VENDOR NAME>/
folder and can use the firmware or its shell (UEFI shell) to launch the boot program. An EFI System Partition is usually formatted as FAT32.
Under UEFI, every program whether it is an OS loader or a utility (e.g. a memory testing app or recovery tool), should be a UEFI Application corresponding to the EFI firmware architecture. The vast majority of UEFI firmwares, including recent Apple Macs, use x86_64 EFI firmware. The only known devices that use i386 EFI are older (pre 2008) Apple Macs.
An x86_64 EFI firmware does not include support for launching 32-bit EFI apps unlike x86_64 Linux and Windows versions which include such support. Therefore the bootloader must be compiled for that specific architecture.
Multibooting on UEFISince each OS or vendor can maintain its own files within the EFI SYSTEM PARTITION without affecting the other, multi-booting using UEFI is just a matter of launching a different UEFI application corresponding to the particular OS’s bootloader. This removes the need for relying on chainloading mechanisms of one bootloader to load another to switch OSes.
To confirm that my Mac was using “x86_64 EFI firmware”, I ran the following:
GRUB and EUFI
Since I will be installing Fedora, I will be using GRUB for my boot loader. Here is how GRUB handles EUFI, from GRUB and the boot process on UEFI-based x86 systems”:
GRUB loads itself into memory in the following stages:
- The UEFI-based platform reads the partition table on the system storage and mounts the EFI System Partition (ESP), a VFAT partition labeled with a particular globally unique identifier (GUID). The ESP contains EFI applications such as bootloaders and utility software, stored in directories specific to software vendors. Viewed from within the Fedora 19 file system, the ESP is /boot/efi/, and EFI software provided by Red Hat is stored in /boot/efi/EFI/fedora/.
The /boot/efi/EFI/fedora/ directory contains grub.efi, a version of GRUB compiled for the EFI firmware architecture as an EFI application. In the simplest case, the EFI boot manager selects grub.efi as the default bootloader and reads it into memory.
If the ESP contains other EFI applications, the EFI boot manager might prompt you to select an application to run, rather than load grub.efi automatically.
- GRUB determines which operating system or kernel to start, loads it into memory, and transfers control of the machine to that operating system.
Because each vendor maintains its own directory of applications in the ESP, chain loading is not normally necessary on UEFI-based systems. The EFI boot manager can load any of the operating system bootloaders that are present in the ESP.
The above sounds great, but with Fedora 19, there is a known bug. From “Common F19 bugs”:
If you try to do a native UEFI install of Fedora 19 alongside a native UEFI install of OS X and re-use the existing EFI system partition, the installer will incorrectly consider the existing EFI system partition as invalid and report that you have not created a bootloader stage1 target device. Unfortunately, the Fedora automatic partitioning algorithm will actually attempt to re-use the EFI system partition, and so you will run into this bug in any Fedora 19 installation attempt where you use the automatic partitioning algorithm and do not choose to delete the existing EFI system partition.
Practically speaking, there are a few different approaches to dealing with this problem. If you do not mind losing your OS X installation, you can simply choose to delete it (including the EFI system partition), and let Fedora occupy the rest of the disk. Fedora should create a new EFI system partition and install successfully.
If you wish to preserve your OS X installation, install Fedora 19 Final, and dual boot, you must use the installer’s ‘custom partitioning’ path. Make sure to leave the existing EFI system partition intact, but do not set a mount point for it. Do not use the Create partitions for me button. Instead, manually create a new EFI system partition, and set it to be mounted at /boot/efi. Manually create other partitions as usual. Complete custom partitioning, and your installation should proceed successfully.
You could also try installing Fedora 18 or Fedora 19 Beta. These should allow you to use automatic partitioning to install alongside OS X, assuming you do not run into any other bugs they may have contained. You could then upgrade to Fedora 19 Final - with FedUp from Fedora 18, or yum from Fedora 19 Beta. You will still wind up with two EFI system partitions in this case.
We are investigating the possibility of producing an updates image to make it easier to deal with this bug. We apologize for any inconvenience it causes you.
It looks like there are still some issues with the new UEFI and different OSes.
Download Appropriate Install Media
From Fedora’s Installation Guide:
Important — UEFI for 32-bit x86 systemsFedora 19 does not support UEFI booting for 32-bit x86 systems. Only BIOS booting is supported.
Important — UEFI for AMD64 and Intel 64Note that the boot configurations of UEFI and BIOS differ significantly from each other. Therefore, the installed system must boot using the same firmware that was used during installation. You cannot install the operating system on a system that uses BIOS and then boot this installation on a system that uses UEFI. Fedora 19 supports version 2.2 of the UEFI specification.
I was going to install to install Fedora 19 64bit from the get-go so this didn’t really impact me.
Shrinking the OS Disk
I just needed 50GB for my Linux install. Before I made any changes, here is how disk was partitioned:
While in Mac OS X, From Utilities (Command-Shift-U), I started up DiskUtility. Then I selected the OS Hard-Drive, selected the Partition tab, re-sized the OS partition , and clicked apply:
That was really easy.
Fedora Sorcerer (le4d) Mac Os Catalina
Install Fedora 19 on Mac Book Pro
After I burned the DVD ISO, I inserted into the Disk drive and rebooted. Right after I rebooted, I held down the “Alt/Option” key and I saw that the following media was bootable:
I selected the Fedora Media and booted from it. During the install I selected the “Custom partition” method and I made the follow partitioning schema:
Even after following the instruction in the bug, it still gave the “you have not created a bootloader stage1 target device” error. So I decided not to install a boot-loader at all. This is done by clicking on “Full Disk Summary and bootloader” and then selecting “Do not install bootloader”:
Fedora Sorcerer (le4d) Mac Os X
After opting out of the bootloading, the install started.
Boot into Rescue Mode and Create the GRUB Configuration manually
After the install finished, I rebooted into the Install DVD again and selected “Troubleshooting”:
I selected to discover any previous Linux installs and the rescue CD mounted it under /mnt/sysimage. After it dropped me into the shell, I did the following to create the GRUB configuration:
I then exited from the recovery shell and let the OS boot. Since I didn’t install any boot loader it booted into Mac OS X.
Bless the Other EFI Partition
To boot from the other EFI partition we need to bless it and set it as bootable. After you boot back into Mac OS X, you will see the following partitions:
You will also notice the second EFI Partition automatically mounted:
So to bless our second EFI partition, we can run the following:
I rebooted one more time and I saw the GRUB menu. After it auto-selected the “Fedora” Menu, it showed the following error:
error: failure to read sector 0x0 from hd0
But then kept booting without issues :) Apparently there is workaround described here, but I wasn’t too worried about it.
Installing the Wireless Firmware
Initially the wireless card won’t be recognized. Here is the lspci output of the card:
I downloaded the firmware from here:
and then installed it like so:
After one more reboot, it came up without issues:
Fixing the Fn Keys
By default the Fn keys will be mapped to the media keys of the Mac Keyboard. To temporarily fix it, you can run the following:
You can then run xev and confirm that your keys are reporting the appropriate key code. Here is how my F1 key looked like after the fix:
To make it permanent, you should be able to add the following into the /etc/modprobe.d/hid_apple.conf file:
But it actually didn’t work out for me. Doing some research it looks like we need to set as a kernel parameter. This is discussed here. You can usually do this with the /etc/sysconfig/grub file on Fedora. For some reason that file didn’t exist on my install (or rather the link was missing). Usually /etc/sysconfig/grub points to /etc/default/grub, but the /etc/default/grub file was missing. I even re-installed the package that provided that file:
But it still didn’t help out, so I created one manually with the following contents:
After that I regenerated the GRUB config:
Then after yet another reboot, the Fn keys were permanently fixed. Another person wrote a systemd service to run the above command upon boot. Check out the instructions at “Changing the default Function key behaviour in Fedora”.
Rebooting into Mac OS X
If you want to reboot into Mac OS X, you can reboot the MacBook Pro and hold down ‘Alt/Option” during the boot and you will available bootable media, like so:
Select “Macintosh HD” and it will boot back into Mac OS X. To set it permanently to boot into Mac OS X. While in Mac OS X, open up System Preferences and select the “Start Up Disk”:
Then select “Macintosh HD” and it will reboot into Mac OS X permanently. Or you can run this command to re-enable boot in the Mac OS HD:
Please enable JavaScript to view the comments powered by Disqus.blog comments powered by Disqus