[PATCH] Handle that the default bootloader entry can sometimes be None (#496618).

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



In certain upgrade cases, the default bootloader entry will never be set
and so at the point where we write the new bootloader config, we'll hit a
traceback condition.  Older versions of anaconda allowed the default entry
to be None here, so we need to do the same.
---
 bootloader.py |   10 +++++++---
 1 files changed, 7 insertions(+), 3 deletions(-)

diff --git a/bootloader.py b/bootloader.py
index 1723458..0c28c8a 100644
--- a/bootloader.py
+++ b/bootloader.py
@@ -146,7 +146,11 @@ def writeBootloader(anaconda):
     otherList = []
     # getDefault needs to return a device, but that's too invasive for now.
     rootDev = anaconda.id.storage.fsset.rootDevice
-    defaultDev = anaconda.id.storage.devicetree.getDeviceByName(anaconda.id.bootloader.images.getDefault())
+
+    if not anaconda.id.bootloader.images.getDefault():
+        defaultDev = None
+    else:
+        defaultDev = anaconda.id.storage.devicetree.getDeviceByName(anaconda.id.bootloader.images.getDefault())
 
     kernelLabel = None
     kernelLongLabel = None
@@ -155,7 +159,7 @@ def writeBootloader(anaconda):
         if (rootDev is None and kernelLabel is None) or (dev == rootDev.name):
 	    kernelLabel = label
             kernelLongLabel = longlabel
-	elif dev == defaultDev.name:
+	elif (not defaultDev and not dev) or (defaultDev and dev == defaultDev.name):
 	    otherList = [(label, longlabel, dev)] + otherList
 	else:
 	    otherList.append((label, longlabel, dev))
@@ -184,7 +188,7 @@ def writeBootloader(anaconda):
     f.write("# UPDATEDEFAULT specifies if new-kernel-pkg should make\n"
             "# new kernels the default\n")
     # only update the default if we're setting the default to linux (#156678)
-    if rootDev.name == defaultDev.name:
+    if (not defaultDev and not rootDev) or (defaultDev and rootDev.name == defaultDev.name):
         f.write("UPDATEDEFAULT=yes\n")
     else:
         f.write("UPDATEDEFAULT=no\n")        
-- 
1.6.1.3

_______________________________________________
Anaconda-devel-list mailing list
Anaconda-devel-list@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/anaconda-devel-list

[Index of Archives]     [Kickstart]     [Fedora Users]     [Fedora Legacy List]     [Fedora Maintainers]     [Fedora Desktop]     [Fedora SELinux]     [Big List of Linux Books]     [Yosemite News]     [Yosemite Photos]     [KDE Users]     [Fedora Tools]
  Powered by Linux