2011-10-13 00:08:31 +00:00
|
|
|
<%page args="kernels, runtime_img, basearch, libdir, inroot, outroot, product, isolabel"/>
|
2011-05-09 14:47:25 +00:00
|
|
|
<%
|
2011-10-21 20:12:12 +00:00
|
|
|
configdir="tmp/config_files/ppc"
|
2011-05-09 14:47:25 +00:00
|
|
|
BOOTDIR="ppc"
|
2013-08-28 22:56:56 +00:00
|
|
|
GRUBDIR="boot/grub"
|
2015-02-27 20:00:44 +00:00
|
|
|
STAGE2IMG="images/install.img"
|
2013-12-09 16:59:26 +00:00
|
|
|
MACDIR=GRUBDIR+"/powerpc-ieee1275"
|
2014-11-05 03:07:57 +00:00
|
|
|
LORAXDIR="usr/share/lorax/"
|
2011-05-09 14:47:25 +00:00
|
|
|
|
2011-11-16 20:02:43 +00:00
|
|
|
## NOTE: yaboot freaks out and stops parsing its config if it sees a '\',
|
|
|
|
## so we can't use the udev escape sequences in the root arg.
|
|
|
|
## Instead we'll just replace any non-ASCII characters in the isolabel
|
|
|
|
## with '_', which means we won't need any udev escapes.
|
|
|
|
isolabel = ''.join(ch if ch.isalnum() else '_' for ch in isolabel)
|
|
|
|
|
2012-07-10 05:34:06 +00:00
|
|
|
## Anaconda finds the CDROM device automatically
|
|
|
|
rootarg = ""
|
2017-03-09 19:08:19 +00:00
|
|
|
|
|
|
|
from os.path import basename
|
2011-05-09 14:47:25 +00:00
|
|
|
%>
|
|
|
|
|
2016-03-14 23:41:09 +00:00
|
|
|
## Test ${runtime_img} to see if udf is needed
|
|
|
|
<%
|
|
|
|
import os
|
|
|
|
from pylorax.sysutils import joinpaths
|
2016-03-23 16:54:48 +00:00
|
|
|
if os.stat(joinpaths(inroot, runtime_img)).st_size >= 4*1024**3:
|
2016-03-14 23:41:09 +00:00
|
|
|
udfargs = "-allow-limited-size"
|
|
|
|
else:
|
|
|
|
udfargs = ""
|
|
|
|
%>
|
|
|
|
|
2015-02-27 20:00:44 +00:00
|
|
|
mkdir images
|
|
|
|
install ${runtime_img} ${STAGE2IMG}
|
|
|
|
treeinfo stage2 mainimage ${STAGE2IMG}
|
2011-06-23 00:22:24 +00:00
|
|
|
|
2011-11-16 19:49:35 +00:00
|
|
|
## install bootloaders.
|
|
|
|
## NOTE: there's two different bootloader setups here:
|
|
|
|
## ppc/chrp: for normal PPC systems. needs 'addnote' run on yaboot.
|
|
|
|
## uses /etc/yaboot.conf, as is the default.
|
|
|
|
## ppc/mac: for PowerMacs. no 'addnote' (it breaks some Macs!)
|
|
|
|
## ofboot.b picks one of /ppc/ppc{32,64}/yaboot.conf for yaboot,
|
|
|
|
## thus automatically booting the correct kernel for the machine.
|
2011-08-09 01:11:28 +00:00
|
|
|
mkdir ${BOOTDIR}
|
2011-11-16 19:49:35 +00:00
|
|
|
## boot stuff for normal (CHRP/PREP) PPC systems
|
2011-08-09 00:35:35 +00:00
|
|
|
install ${configdir}/bootinfo.txt ${BOOTDIR}
|
2013-08-28 22:56:56 +00:00
|
|
|
|
|
|
|
mkdir ${GRUBDIR}/powerpc-ieee1275
|
2018-04-19 10:28:55 +00:00
|
|
|
## "()" means the current device to grub2
|
|
|
|
runcmd grub2-mkimage --format=powerpc-ieee1275 --directory=/usr/lib/grub/powerpc-ieee1275 --prefix="()/"${GRUBDIR} \
|
|
|
|
--output=${outroot}/${GRUBDIR}/powerpc-ieee1275/core.elf iso9660 ext2 ofnet net tftp http
|
2013-08-28 22:56:56 +00:00
|
|
|
install /usr/lib/grub/powerpc-ieee1275/*.mod ${GRUBDIR}/powerpc-ieee1275
|
|
|
|
install /usr/lib/grub/powerpc-ieee1275/*.lst ${GRUBDIR}/powerpc-ieee1275
|
|
|
|
|
|
|
|
install ${configdir}/grub.cfg.in ${GRUBDIR}/grub.cfg
|
|
|
|
replace @PRODUCT@ '${product.name}' ${GRUBDIR}/grub.cfg
|
|
|
|
replace @VERSION@ ${product.version} ${GRUBDIR}/grub.cfg
|
|
|
|
replace @ROOT@ "${rootarg}" ${GRUBDIR}/grub.cfg
|
2011-05-09 14:47:25 +00:00
|
|
|
|
2012-05-25 11:47:33 +00:00
|
|
|
install ${configdir}/mapping ${BOOTDIR}
|
|
|
|
|
2011-10-21 20:12:12 +00:00
|
|
|
## NOTE: PPC is kind of funky. There's three possible "arch" setups here:
|
2014-09-02 17:58:48 +00:00
|
|
|
## ppc, ppc64, ppc64le, and 'hybrid' (ppc userspace, both ppc & ppc64 kernels).
|
2011-10-21 20:12:12 +00:00
|
|
|
|
|
|
|
## Install kernel and bootloader config (in separate places for each arch)
|
2011-05-09 14:47:25 +00:00
|
|
|
%for kernel in kernels:
|
|
|
|
<%
|
2018-04-19 10:28:55 +00:00
|
|
|
bits = 64
|
2011-10-21 20:12:12 +00:00
|
|
|
## separate dirs/images for each arch
|
2011-05-09 14:47:25 +00:00
|
|
|
KERNELDIR=BOOTDIR+"/ppc%s" % bits
|
|
|
|
%>
|
2011-10-21 20:12:12 +00:00
|
|
|
## install kernel
|
2018-04-19 10:28:55 +00:00
|
|
|
mkdir ${KERNELDIR}
|
2011-05-09 14:47:25 +00:00
|
|
|
installkernel images-${kernel.arch} ${kernel.path} ${KERNELDIR}/vmlinuz
|
|
|
|
installinitrd images-${kernel.arch} ${kernel.initrd.path} ${KERNELDIR}/initrd.img
|
|
|
|
|
2018-04-19 10:28:55 +00:00
|
|
|
treeinfo images-${kernel.arch} zimage
|
2011-05-09 14:47:25 +00:00
|
|
|
%endfor
|
|
|
|
|
2014-11-05 03:07:57 +00:00
|
|
|
# Create optional product.img and updates.img
|
2017-03-09 19:08:19 +00:00
|
|
|
<% filegraft=""; images=["product", "updates"] %>
|
2014-11-05 03:07:57 +00:00
|
|
|
%for img in images:
|
|
|
|
%if exists("%s/%s/" % (LORAXDIR, img)):
|
|
|
|
installimg ${LORAXDIR}/${img}/ images/${img}.img
|
2016-05-11 00:39:01 +00:00
|
|
|
treeinfo images-${basearch} ${img}.img images/${img}.img
|
2017-03-09 19:08:19 +00:00
|
|
|
<% filegraft += " images/{0}.img={1}/images/{0}.img".format(img, outroot) %>
|
2014-11-05 03:07:57 +00:00
|
|
|
%endif
|
|
|
|
%endfor
|
|
|
|
|
Add ability for external templates to graft content into boot.iso
I originally added --add-template to support doing something similar
to pungi, which injects content into the system to be used by default.
However, this causes the content to be part of the squashfs, which
means PXE installations have to download significantly more data that
they may not need (if they actually want to pull the tree data from
the network, which is not an unusual case).
What I actually need is to be able to modify *both* the runtime image
and the arch-specific content. For the runtime, I need to change
/usr/share/anaconda/interactive-defaults.ks to point to the new
content. (Although, potentially we could patch Anaconda itself to
auto-detect an ostree repository configured in disk image, similar to
what it does for yum repositories)
For the arch-specfic image, I want to drop my content into the ISO
root.
So this patch adds --add-arch-template and --add-arch-template-var
in order to do the latter, while preserving the --add-template
to affect the runtime image.
Further, the templates will automatically graft in a directory named
"iso-graft/" from the working directory (if it exists).
(I suggest that external templates create a subdirectory named
"content" to avoid clashes with any future lorax work)
Thus, this will be used by the Atomic Host lorax templates to inject
content/repo, but could be used by e.g. pungi to add content/rpms as
well.
I tried to avoid code deduplication by creating a new template for the
product.img bits and this, but that broke because the parent boot.iso
code needs access to the `${imggraft}` variable. I think a real fix
here would involve turning the product.img, content/, *and* boot.iso
into a new template.
2015-03-17 21:26:21 +00:00
|
|
|
# Inherit iso-graft/ if it exists from external templates
|
|
|
|
<%
|
|
|
|
import os
|
|
|
|
if os.path.exists(workdir + "/iso-graft"):
|
2017-03-09 19:08:19 +00:00
|
|
|
filegraft += " " + workdir + "/iso-graft"
|
Add ability for external templates to graft content into boot.iso
I originally added --add-template to support doing something similar
to pungi, which injects content into the system to be used by default.
However, this causes the content to be part of the squashfs, which
means PXE installations have to download significantly more data that
they may not need (if they actually want to pull the tree data from
the network, which is not an unusual case).
What I actually need is to be able to modify *both* the runtime image
and the arch-specific content. For the runtime, I need to change
/usr/share/anaconda/interactive-defaults.ks to point to the new
content. (Although, potentially we could patch Anaconda itself to
auto-detect an ostree repository configured in disk image, similar to
what it does for yum repositories)
For the arch-specfic image, I want to drop my content into the ISO
root.
So this patch adds --add-arch-template and --add-arch-template-var
in order to do the latter, while preserving the --add-template
to affect the runtime image.
Further, the templates will automatically graft in a directory named
"iso-graft/" from the working directory (if it exists).
(I suggest that external templates create a subdirectory named
"content" to avoid clashes with any future lorax work)
Thus, this will be used by the Atomic Host lorax templates to inject
content/repo, but could be used by e.g. pungi to add content/rpms as
well.
I tried to avoid code deduplication by creating a new template for the
product.img bits and this, but that broke because the parent boot.iso
code needs access to the `${imggraft}` variable. I think a real fix
here would involve turning the product.img, content/, *and* boot.iso
into a new template.
2015-03-17 21:26:21 +00:00
|
|
|
%>
|
|
|
|
|
2017-03-09 19:08:19 +00:00
|
|
|
# Add the license files
|
|
|
|
%for f in glob("/usr/share/licenses/*-release/*"):
|
|
|
|
install ${f} ${f|basename}
|
|
|
|
<% filegraft += " {0}={1}/{0}".format(basename(f), outroot) %>
|
|
|
|
%endfor
|
|
|
|
|
2011-10-21 20:12:12 +00:00
|
|
|
## make boot.iso
|
2011-05-09 14:47:25 +00:00
|
|
|
runcmd mkisofs -o ${outroot}/images/boot.iso -chrp-boot -U \
|
2018-04-19 10:28:55 +00:00
|
|
|
-part -hfs -T -r -l -J \
|
2011-10-13 00:08:31 +00:00
|
|
|
-A "${product.name} ${product.version}" -sysid PPC -V '${isolabel}' \
|
2011-05-09 14:47:25 +00:00
|
|
|
-volset "${product.version}" -volset-size 1 -volset-seqno 1 \
|
2011-07-26 00:09:54 +00:00
|
|
|
-hfs-volid ${product.version} -hfs-bless ${outroot}/${MACDIR} \
|
2011-08-09 01:11:28 +00:00
|
|
|
-map ${inroot}/${configdir}/mapping \
|
2016-03-14 23:41:09 +00:00
|
|
|
-no-desktop -allow-multidot ${udfargs} -graft-points \
|
2011-07-26 00:09:54 +00:00
|
|
|
${BOOTDIR}=${outroot}/${BOOTDIR} \
|
2013-08-28 22:56:56 +00:00
|
|
|
${GRUBDIR}=${outroot}/${GRUBDIR} \
|
2017-03-09 19:08:19 +00:00
|
|
|
${STAGE2IMG}=${outroot}/${STAGE2IMG} ${filegraft}
|
2014-11-05 03:07:57 +00:00
|
|
|
|
2011-11-16 19:49:35 +00:00
|
|
|
%for kernel in kernels:
|
2011-05-09 14:47:25 +00:00
|
|
|
treeinfo images-${kernel.arch} boot.iso images/boot.iso
|
2011-11-16 19:49:35 +00:00
|
|
|
%endfor
|