(→Boot Options: nofirewire) |
(review doc) |
||
(19 intermediate revisions by one other user not shown) | |||
Line 11: | Line 11: | ||
== Current status == | == Current status == | ||
* Targeted release: [[Releases/17|Fedora 17]] | * Targeted release: [[Releases/17|Fedora 17]] | ||
* Last updated: Nov. | * Last updated: Nov. 14, 2011 | ||
* Percentage of completion: 50% | * Percentage of completion: 50% | ||
Line 32: | Line 32: | ||
We need to decide how many of these tasks anaconda still needs to do. For those that are still important, they need to move either into the initramfs (if it's something that needs to happen before anaconda can start) or into the main anaconda program - or some other tool that anaconda can run when we're in the full graphical environment. Everything else should go away. | We need to decide how many of these tasks anaconda still needs to do. For those that are still important, they need to move either into the initramfs (if it's something that needs to happen before anaconda can start) or into the main anaconda program - or some other tool that anaconda can run when we're in the full graphical environment. Everything else should go away. | ||
This may mean we keep some sort of loader-like program, but it could be Python based and non-interactive. | This may mean we keep some sort of loader-like program, but it could be Python-based and non-interactive. | ||
== Benefit to Fedora == | == Benefit to Fedora == | ||
Line 41: | Line 41: | ||
* Debuggability! | * Debuggability! | ||
** There's a shell available as soon as the installer boots | ** There's a shell available as soon as the installer boots | ||
** Every part of the anaconda startup process becomes much easier to modify | ** Every part of the anaconda startup process becomes much easier to modify since it's all shell or python | ||
* Flexibility! | * Flexibility! | ||
** Moving to dracut-based initramfs means that anaconda can mount anything that dracut can mount | ** Moving to dracut-based initramfs means that anaconda can mount anything that dracut can mount | ||
Line 50: | Line 50: | ||
== Scope == | == Scope == | ||
There are 3 major sets of things that loader does: interactive screens, boot arguments, and kickstart commands. | |||
{{admon/warning|Work In Progress|These sections are still being filled in. Contents are volatile. Filling may be hot.}} | |||
=== Interactive Screens === | === Interactive Screens === | ||
All interactive prompts presented by loader will either be moved later (into anaconda proper) or earlier (configure on boot command line). | |||
{| | {| | ||
! Step | ! Step Names !! Status !! Handled By !! Notes !! Complete? | ||
|- | |- | ||
| | | <code>STEP_LANG</code> || move || anaconda || already present in anaconda UI || Yes | ||
|- | |- | ||
| | | <code>STEP_KBD</code> || move || anaconda || already present in anaconda UI || Yes | ||
|- | |- | ||
| | | <code>STEP_METHOD</code> || boot opt || dracut || only needed for netboot.<br/>use <code>repo=</code>, verify validity, give clear error message on failure || | ||
|- | |- | ||
| | | <code>STEP_DRIVER</code> || boot opt || dracut || unlikely, usually represents a bug.<br/>use <code>rd.driver.pre</code> and/or <code>rd.driver.post</code> to manually load drivers.<br/>fail with a clear error message if we can't find usable devices at boot. || | ||
|- | |- | ||
| | | <code>STEP_DRIVERDISK</code> || boot opt || dracut || make <code>dd</code>/<code>driverdisk</code> take an argument specifying location. || | ||
|- | |- | ||
| STEP_IP | | <code>STEP_NETWORK<br/>STEP_IFACE<br/>STEP_IP</code> || boot opt || dracut || configure network at boot prompt<br/>if network required and unconfigured, try autoconfig (dhcp/auto6/etc). || | ||
|- | |- | ||
| STEP_EXTRAS | | <code>STEP_EXTRAS</code> || keep || dracut || non-interactive check for <code>updates.img</code>/<code>product.img</code> inside installation source || | ||
|} | |} | ||
Line 80: | Line 81: | ||
Some options (e.g. <code>[[Anaconda Boot Options#autostep|autostep]]</code>, <code>[[Anaconda Boot Options#nogpt|nogpt]]</code>) are handled by the main anaconda program and don't need to be changed.}} | Some options (e.g. <code>[[Anaconda Boot Options#autostep|autostep]]</code>, <code>[[Anaconda Boot Options#nogpt|nogpt]]</code>) are handled by the main anaconda program and don't need to be changed.}} | ||
Some boot options may be removed since they no longer apply.<br/>Anything that says '''deprecate''' ''will still be accepted'' (with a warning/error message) for a release or two. | |||
<!-- yeah this list needs to be reorganized. it's a wiki; feel free. --> | |||
{| | {| | ||
! Boot Option !! | ! Boot Option !! Status !! Handled in !! Notes !! Done? | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#askmethod|askmethod]] || REMOVE || bootloader || use <code>repo=</code> || YES | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#asknetwork|asknetwork]] || REMOVE || bootloader || use <code>ip=</code> || YES | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#blacklist|blacklist=<module>]] || DEPRECATE || dracut | ||
| <code>rd.driver.blacklist=<module></code> | |||
| | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#dd|dd]]<br/>[[Anaconda/Options#driverdisk|driverdisk]] || KEEP || dracut || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#display|display=<display>]] || KEEP? || anaconda | ||
| just exports <code>DISPLAY=<display></code> | |||
| | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#gdb|gdb]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#graphical|graphical]]<br/>[[Anaconda/Options#text|text]]<br/>[[Anaconda/Options#cmdline|cmdline]] | ||
| KEEP || anaconda || anaconda can figure this out itself || | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#keymap|keymap=<keymap>]] || KEEP || dracut | ||
| Implies <code>vconsole.keymap=<keymap></code> | |||
| | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#ks|ks]] || KEEP || dracut || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#lang|lang=<lang>]] || KEEP || dracut/anaconda | ||
| Implies <code>locale.LANG=<lang></code> (and/or <code>locale.LC_ALL=<lang></code>?) | |||
| | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#loglevel|loglevel]] || KEEP || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#mediacheck|mediacheck]] || KEEP || anaconda || if the media's so bad we can't get into anaconda, we'll know. || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#method|method]] || DEPRECATE || dracut || <code>repo</code> || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#nofirewire|nofirewire]] || DEPRECATE || dracut || <code>blacklist=firewire-ohci</code> || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#nokill|nokill]] || KEEP || anaconda || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#nopass|nopass]] || REMOVE || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#noprobe|noprobe]] || REMOVE || || useless - skips a <code>udevadm trigger</code> after it's already been run twice || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#noshell|noshell]] || KEEP || systemd || shell on <code>tty2</code>/<code>hvc1</code> is set up by <code>anaconda-shell@.service</code> || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#nousb|nousb]] || REMOVE || kernel || the kernel handles <code>nousb</code> itself these days. || YES | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#noverifyssl|noverifyssl]] || KEEP || dracut/anaconda || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#repo|repo]] || KEEP || dracut | ||
| set <code>root=live:XXX</code> from <code>repo</code> value | |||
| | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#rescue|rescue]] || KEEP || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#selinux|selinux]]<br/>[[Anaconda/Options#noselinux|noselinux]] || DEPRECATE || use <code>enforcing=0</code> or <code>selinux=0</code> instead || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#serial|serial]] || DEPRECATE || || <code>console=ttyS0</code> || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#sshd|sshd]] || KEEP || systemd || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#syslog|syslog]] || KEEP || || TODO || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#updates|updates]] || KEEP || dracut || TODO || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#utf8|utf8]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#vncpassword|vncpassword]] || KEEP || anaconda || || | ||
|- | |- | ||
| | !colspan=5|NETWORK | ||
|- | |- | ||
! Boot Option !! Status !! Handled in !! Notes !! Done? | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#ip|ip]] || MODIFIED || dracut | ||
| <code>ip=<nowiki>{dhcp|dhcp6|auto6|ibft}</nowiki></code><br/>see [http://people.redhat.com/harald/dracut.html#dracut.kernel dracut.kernel(7)] and items below | |||
| | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#ipv6|ipv6]] || DEPRECATE || dracut | ||
|<code>ip=<nowiki>{[v6addr:goes::here]|auto6|dhcp6}</nowiki></code> | |||
| | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#dns|dns=<ip>]] || DEPRECATE || dracut || <code>nameserver=<ip></code> || | ||
|- | |- | ||
| [[Anaconda/Options# | |[[Anaconda/Options#gateway|gateway=<gw>]]<br/>[[Anaconda/Options#netmask|netmask=<nm>]] | ||
| DEPRECATE || dracut | |||
|<code>ip=<ip>::<gw>:<nm>:<hostname>:<iface></code> | |||
| | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#dhcpclass|dhcpclass]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#dhcptimeout|dhcptimeout]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#ethtool|ethtool]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#mtu|mtu]] || KEEP || dracut || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#ksdevice|ksdevice]] || KEEP || dracut || add special handling for <code>link</code>, <code>bootif</code>, <code>ibft</code>? || | ||
|- | |- | ||
| [[Anaconda/Options# | |[[Anaconda/Options#kssendmac|kssendmac]]<br/>[[Anaconda/Options#kssendsn|kssendsn]] | ||
| KEEP || dracut || || | |||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#linksleep|linksleep]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#nicdelay|nicdelay]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#noipv4|noipv4]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#noipv6|noipv6]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#proxy|proxy]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options# | | [[Anaconda/Options#essid|essid]] || || || || | ||
|- | |- | ||
| [[Anaconda/Options#wepkey|wepkey]]<br/>[[Anaconda/Options#wpakey|wpakey]] || || || || | |||
|} | |} | ||
=== Kickstart Commands === | === Kickstart Commands === | ||
Yes, loader | {{admon/note|This is not the main kickstart parser|<code>loader</code> only handles ''commands that might be needed to find the anaconda runtime''. The anaconda runtime contains the normal kickstart parser which handles all the [[Anaconda/Kickstart|usual kickstart commands]].}} | ||
Yes, loader has its own kickstart parser. Here are the kickstart items it cares about. | |||
{| | {| | ||
! Kickstart Command !! | ! Kickstart Command !! Handled by !! Notes !! Done? | ||
|- | |||
| [[Anaconda/Kickstart#lang|lang]]<br/>[[Anaconda/Kickstart#keyboard|keyboard]] || dracut || see lang/keymap above || | |||
|- | |||
| [[Anaconda/Kickstart#network|network]] || dracut || see dns/mtu/dhcpclass/etc. above || | |||
|- | |||
| [[Anaconda/Kickstart#mediacheck|mediacheck]] || dracut || || | |||
|- | |||
| [[Anaconda/Kickstart#install|install]]<br/> || dracut || includes <code>cdrom</code>, <code>harddrive</code>, <code>nfs</code>, and <code>url</code> || | |||
|- | |||
| [[Anaconda/Kickstart#selinux|selinux]] || anaconda || systemd loads SELinux policy if needed || Yes | |||
|- | |||
| [[Anaconda/Kickstart#graphical|graphical]]<br/>[[Anaconda/Kickstart#text|text]]<br/>[[Anaconda/Kickstart#cmdline|cmdline]] || anaconda || || | |||
|- | |||
| [[Anaconda/Kickstart#vnc|vnc]] || dracut || || | |||
|- | |||
| [[Anaconda/Kickstart#updates|updates]] || dracut || || | |||
|- | |||
| [[Anaconda/Kickstart#driverdisk|driverdisk]] || dracut || || | |||
|- | |- | ||
| [[Anaconda/Kickstart# | | [[Anaconda/Kickstart#%include|%include]] || dracut || || | ||
|- | |- | ||
|} | |} | ||
== Test Plan == | == Test Plan == | ||
The normal [[Category:Install_Test_Plans|Install Test Plans]] should suffice. | The normal [[:Category:Install_Test_Plans|Install Test Plans]] should suffice. | ||
== User Experience == | == User Experience == | ||
Line 207: | Line 242: | ||
TBD. Some notes: | TBD. Some notes: | ||
* We may remove all the interactive bits, so a few things | * We may remove all the interactive bits, so a few things they're used to be (crappy text-based) UI for will now be configured on the boot command line and/or in the bootloader menu. | ||
* Some of the [[Anaconda/Options|anaconda boot options]] may change or become deprecated. | * Some of the [[Anaconda/Options|anaconda boot options]] may change or become deprecated. | ||
** We will do our best to keep | ** We will do our best to keep backward compatibility - for a few releases. | ||
== Dependencies == | == Dependencies == |
Latest revision as of 08:19, 8 August 2018
Get rid of anaconda's loader
Summary
Stop using our old, crufty, hard-to-maintain C-based custom initrd. Move everything out of loader
and into dracut or anaconda proper.
Owner
Current status
- Targeted release: Fedora 17
- Last updated: Nov. 14, 2011
- Percentage of completion: 50%
Detailed Description
Since 1999, anaconda has been divided into two parts:
- stage1, a.k.a.
initrd.img
: the blue and red textloader
environment (no shell, no virtual terminals, just a custom startup binary written in C - statically linked until 2008) - stage2, a.k.a.
install.img
: the full installer environment (for graphical or text installs), complete with Python interpreter and shells and stuff.
In olden days, loader did what its name says - it loaded the stage2 (full graphical) anaconda environment and did a couple other tasks required to reach that objective. Those other tasks include things like:
- Prompting for language and keyboard (if loader goes interactive for one of the other tasks)
- Bringing up the network (if required by one of the other tasks)
- Fetching kickstart files, product.img, and updates.img (if requested)
- Loading driver disks (if required)
- Running media check
Most of the time, all of these things are skipped or happen automatically. If you use a boot.iso, you will most likely never see anything besides a blue background and the "Loading anaconda..." message. This means it's a whole lot of code that is just special cases and receives less testing all the time. Further, it's a special environment: It's newt, it's C, it's old, and it's another layer of stuff getting execed between startup and anaconda.
We need to decide how many of these tasks anaconda still needs to do. For those that are still important, they need to move either into the initramfs (if it's something that needs to happen before anaconda can start) or into the main anaconda program - or some other tool that anaconda can run when we're in the full graphical environment. Everything else should go away.
This may mean we keep some sort of loader-like program, but it could be Python-based and non-interactive.
Benefit to Fedora
- Maintainability!
- Gobs of custom code will move into upstream dracut modules or nice neat Python modules.
- New stuff added to dracut will automatically appear in the installer!
- Debuggability!
- There's a shell available as soon as the installer boots
- Every part of the anaconda startup process becomes much easier to modify since it's all shell or python
- Flexibility!
- Moving to dracut-based initramfs means that anaconda can mount anything that dracut can mount
- preupgrade won't need need to cram files into /boot anymore!
- Moving to dracut-based initramfs means that anaconda can mount anything that dracut can mount
- Consistency!
- The installer boots up the same way as a normal system, and the same as the Live images
Scope
There are 3 major sets of things that loader does: interactive screens, boot arguments, and kickstart commands.
Interactive Screens
All interactive prompts presented by loader will either be moved later (into anaconda proper) or earlier (configure on boot command line).
Step Names | Status | Handled By | Notes | Complete? |
---|---|---|---|---|
STEP_LANG |
move | anaconda | already present in anaconda UI | Yes |
STEP_KBD |
move | anaconda | already present in anaconda UI | Yes |
STEP_METHOD |
boot opt | dracut | only needed for netboot. use repo= , verify validity, give clear error message on failure |
|
STEP_DRIVER |
boot opt | dracut | unlikely, usually represents a bug. use rd.driver.pre and/or rd.driver.post to manually load drivers.fail with a clear error message if we can't find usable devices at boot. |
|
STEP_DRIVERDISK |
boot opt | dracut | make dd /driverdisk take an argument specifying location. |
|
STEP_NETWORK |
boot opt | dracut | configure network at boot prompt if network required and unconfigured, try autoconfig (dhcp/auto6/etc). |
|
STEP_EXTRAS |
keep | dracut | non-interactive check for updates.img /product.img inside installation source |
Boot Options
Some boot options may be removed since they no longer apply.
Anything that says deprecate will still be accepted (with a warning/error message) for a release or two.
Boot Option | Status | Handled in | Notes | Done? |
---|---|---|---|---|
askmethod | REMOVE | bootloader | use repo= |
YES |
asknetwork | REMOVE | bootloader | use ip= |
YES |
blacklist=<module> | DEPRECATE | dracut | rd.driver.blacklist=<module>
|
|
dd driverdisk |
KEEP | dracut | ||
display=<display> | KEEP? | anaconda | just exports DISPLAY=<display>
|
|
gdb | ||||
graphical text cmdline |
KEEP | anaconda | anaconda can figure this out itself | |
keymap=<keymap> | KEEP | dracut | Implies vconsole.keymap=<keymap>
|
|
ks | KEEP | dracut | ||
lang=<lang> | KEEP | dracut/anaconda | Implies locale.LANG=<lang> (and/or locale.LC_ALL=<lang> ?)
|
|
loglevel | KEEP | |||
mediacheck | KEEP | anaconda | if the media's so bad we can't get into anaconda, we'll know. | |
method | DEPRECATE | dracut | repo |
|
nofirewire | DEPRECATE | dracut | blacklist=firewire-ohci |
|
nokill | KEEP | anaconda | ||
nopass | REMOVE | |||
noprobe | REMOVE | useless - skips a udevadm trigger after it's already been run twice |
||
noshell | KEEP | systemd | shell on tty2 /hvc1 is set up by anaconda-shell@.service |
|
nousb | REMOVE | kernel | the kernel handles nousb itself these days. |
YES |
noverifyssl | KEEP | dracut/anaconda | ||
repo | KEEP | dracut | set root=live:XXX from repo value
|
|
rescue | KEEP | |||
selinux noselinux |
DEPRECATE | use enforcing=0 or selinux=0 instead |
||
serial | DEPRECATE | console=ttyS0 |
||
sshd | KEEP | systemd | ||
syslog | KEEP | TODO | ||
updates | KEEP | dracut | TODO | |
utf8 | ||||
vncpassword | KEEP | anaconda | ||
NETWORK | ||||
Boot Option | Status | Handled in | Notes | Done? |
ip | MODIFIED | dracut | ip={dhcp|dhcp6|auto6|ibft} see dracut.kernel(7) and items below |
|
ipv6 | DEPRECATE | dracut | ip={[v6addr:goes::here]|auto6|dhcp6}
|
|
dns=<ip> | DEPRECATE | dracut | nameserver=<ip> |
|
gateway=<gw> netmask=<nm> |
DEPRECATE | dracut | ip=<ip>::<gw>:<nm>:<hostname>:<iface>
|
|
dhcpclass | ||||
dhcptimeout | ||||
ethtool | ||||
mtu | KEEP | dracut | ||
ksdevice | KEEP | dracut | add special handling for link , bootif , ibft ? |
|
kssendmac kssendsn |
KEEP | dracut | ||
linksleep | ||||
nicdelay | ||||
noipv4 | ||||
noipv6 | ||||
proxy | ||||
essid | ||||
wepkey wpakey |
Kickstart Commands
Yes, loader has its own kickstart parser. Here are the kickstart items it cares about.
Kickstart Command | Handled by | Notes | Done? |
---|---|---|---|
lang keyboard |
dracut | see lang/keymap above | |
network | dracut | see dns/mtu/dhcpclass/etc. above | |
mediacheck | dracut | ||
install |
dracut | includes cdrom , harddrive , nfs , and url |
|
selinux | anaconda | systemd loads SELinux policy if needed | Yes |
graphical text cmdline |
anaconda | ||
vnc | dracut | ||
updates | dracut | ||
driverdisk | dracut | ||
%include | dracut |
Test Plan
The normal Install Test Plans should suffice.
User Experience
TBD. Some notes:
- We may remove all the interactive bits, so a few things they're used to be (crappy text-based) UI for will now be configured on the boot command line and/or in the bootloader menu.
- Some of the anaconda boot options may change or become deprecated.
- We will do our best to keep backward compatibility - for a few releases.
Dependencies
TBD; currently none.
Contingency Plan
Leave the system as-is - one big combined image, with loader still setting up for anaconda.