Resflash: Difference between revisions
(qui) |
No edit summary |
||
Line 1: | Line 1: | ||
===Building == | |||
notes for building [https://stable.rcesoftware.com/resflash/ resflash] for octeon ([https://www.ui.com/edgemax/edgerouter-lite/ edgerouter lite]). Octeon resflash images require a custom kernel. Resflash loads this into a fat partition, and the kernel needs to know where to find the root partition. | notes for building [https://stable.rcesoftware.com/resflash/ resflash] for octeon ([https://www.ui.com/edgemax/edgerouter-lite/ edgerouter lite]). Octeon resflash images require a custom kernel. Resflash loads this into a fat partition, and the kernel needs to know where to find the root partition. | ||
Line 30: | Line 31: | ||
Now extract the distribution octeon sets from the matching release to /usr/release and you should be able to run build_resflash.sh and create a working image for resflash. Be sure to run | Now extract the distribution octeon sets from the matching release to /usr/release and you should be able to run build_resflash.sh and create a working image for resflash. Be sure to run | ||
build_resflash.sh from an octeon system as well. Partitions created by build_resflash.sh on a differernt architecture are not mountable from an octeon system. | build_resflash.sh from an octeon system as well. Partitions created by build_resflash.sh on a differernt architecture are not mountable from an octeon system. | ||
==running== |
Revision as of 21:56, 21 February 2019
=Building
notes for building resflash for octeon (edgerouter lite). Octeon resflash images require a custom kernel. Resflash loads this into a fat partition, and the kernel needs to know where to find the root partition.
If you want to avoid cross compiling (I did), first do a basic install of openbsd per here. Be sure to include the comp set. Then mount /usr/src on external storage (to avoid unnecessary compile related iops to usb)like nfs. Then run below script to create the kernel:
Here's the build instructions:
#!/bin/ksh export DESTDIR=/usr/dest RELEASEDIR=/usr/release MACHINE='octeon' NCPU=1 MYKERNEL=GENERIC DATEARG='+%H:%M:%S' part=d mkdir ${RELEASEDIR} chown build:wobj ${RELEASEDIR} echo "$(date "${DATEARG}") ${0}: ----- Building bsd.${part} -----" cd /usr/src/sys/arch/${MACHINE}/conf sed "/^config.*bsd/s/config.*/config bsd root on sd0${part} swap on sd0b/" \ GENERIC > GENERIC.${part} sed "/^include.*GENERIC/s/GENERIC/GENERIC.${part}/" GENERIC.MP > \ GENERIC.MP.${part} config ${MYKERNEL}.${part} rm GENERIC.${part} GENERIC.MP.${part} cd ../compile/${MYKERNEL}.${part} make -j ${NCPU} cp obj/bsd ${RELEASEDIR}/bsd.${part} cd .. rm -rf ${MYKERNEL}.${part} rm -rf /usr/obj/sys/arch/${MACHINE}/compile/${MYKERNEL}.${part} cd ${RELEASEDIR} cksum -a sha256 -b bsd.d >> SHA256.bsd.d
Now extract the distribution octeon sets from the matching release to /usr/release and you should be able to run build_resflash.sh and create a working image for resflash. Be sure to run build_resflash.sh from an octeon system as well. Partitions created by build_resflash.sh on a differernt architecture are not mountable from an octeon system.