148 lines
6.3 KiB
Markdown
Raw Normal View History

# What
2014-12-03 00:24:22 +01:00
2021-01-12 14:21:18 +01:00
It's a script to build a customized
2022-09-19 10:39:19 +02:00
[OpenWrt](https://openwrt.org/docs/guide-user/start)
2021-01-12 14:21:18 +01:00
firmware image using
[ImageBuilder](https://openwrt.org/docs/guide-user/additional-software/imagebuilder).
2015-05-28 01:34:10 +02:00
2021-10-19 14:27:15 +02:00
If the generated image is flashed on a device it will try to
automatically set up
[extroot](https://openwrt.org/docs/guide-user/additional-software/extroot_configuration)
2021-10-19 14:27:15 +02:00
on **any (!)** storage device plugged into the USB port (`/dev/sda`),
including your working extroot pendrive if you plug it in only later
in the boot process. Keep in mind that **this will erase any inserted
storage device while the router is in the initial setup phase**!
Unfortunately there's little that can be done at that point to ask the
user for confirmation.
# Why
2015-11-13 12:26:05 +01:00
So that e.g. customers can buy a router on their own, flash our custom
firmware, plug in a pendrive, and manage their SIP (telephony) node
from our webapp.
2017-04-21 03:09:09 +02:00
I've extracted the generic parts from the above mentioned auto-provision
project because I thought it's useful enough for making it public.
2015-11-13 12:26:05 +01:00
# How
2022-09-19 10:39:19 +02:00
You can read more about the underlying technology on the OpenWrt wiki: see e.g. the
[ImageBuilder](https://openwrt.org/docs/guide-user/additional-software/imagebuilder)
2021-01-12 14:21:18 +01:00
page, or the page that lists some other
[ImageBuilder frontends](https://openwrt.org/docs/guide-developer/imagebuilder_frontends).
2021-10-19 14:27:15 +02:00
As for the actual mechanism: custom scripts are baked into the boot
process of the flashed firmware. If the extroot overlay is properly
set up, then these scripts get hidden by it; i.e. they will only run
when the extroot has failed to mount early in the boot process.
2015-11-13 12:26:05 +01:00
### Building
2022-09-19 10:39:19 +02:00
OpenWrt's ImageBuilder only works on Linux x86_64. To build a firmware, issue the following command:
2021-01-12 14:21:18 +01:00
`./build.sh architecture variant device-profile`, e.g.:
2021-10-19 14:27:15 +02:00
* `./build.sh ath79 generic tplink_tl-wr1043nd-v1`
2021-02-14 10:05:55 +01:00
* `./build.sh ath79 generic tplink_archer-c6-v2`
2021-10-19 14:27:15 +02:00
* `./build.sh ath79 generic tplink_tl-wdr4300-v1`
* `./build.sh bcm53xx generic dlink_dir-885l`
Results will be under `build/openwrt-imagebuilder-${release}-${architecture}-${variant}.Linux-x86_64/bin/`.
2017-04-21 02:28:41 +02:00
To see a list of available targets, run `make info` in the ImageBuilder dir.
2022-09-19 10:39:19 +02:00
If you want to change which OpenWrt version is used, then edit the relevant variable(s)
in `build.sh`.
2015-11-15 16:51:42 +01:00
### Setup stages
2015-11-13 12:26:05 +01:00
Blinking leds show which phase the extroot setup scripts are in. Consult the
sources for details: [autoprovision-functions.sh](image-extras/common/root/autoprovision-functions.sh#L49).
2015-11-15 16:51:42 +01:00
#### Stage 1: setup extroot
2017-04-21 03:09:09 +02:00
When the custom firmware first boots, the autoprovision script will
2015-11-15 16:51:42 +01:00
wait for anything (!) in `/dev/sda` to show up (that is >= 512M), then erase
it and set up a `swap`, an `extroot`, and a `data`filesystem (for the remaining
space), and then reboot.
2015-11-15 16:51:42 +01:00
#### Stage 2: download and install some packages from the internet
2021-01-12 14:21:18 +01:00
Once it rebooted into the new extroot, it will continuously keep trying to install
2022-09-19 10:39:19 +02:00
some OpenWrt packages until an internet connection is set up on the router. You
2021-01-12 14:21:18 +01:00
need to do that manually either by using ssh or the web UI (LuCI).
#### Stage 3, optional
We also have a 3rd stage, written in Python, but it's commented out here.
Search for `autoprovision-stage3.py` to see how it's done.
2015-05-28 00:52:13 +02:00
2015-11-13 12:26:05 +01:00
### Login
After flashing the firmware the router will have the standard
2015-11-15 16:51:42 +01:00
`192.168.1.1` IP address.
2015-11-13 12:26:05 +01:00
2015-11-15 16:51:42 +01:00
By default the root passwd is not set, so the router will start telnet with
no password. If you want to set up a password, then edit the stage 2 script:
[autoprovision-stage2.sh](image-extras/common/root/autoprovision-stage2.sh#L53).
2022-09-19 10:39:19 +02:00
If a password is set, then telnet is disabled by OpenWrt and SSH will listen
2015-11-15 16:51:42 +01:00
using the keys specified in [authorized_keys](image-extras/common/etc/dropbear/authorized_keys).
Once connected, you can read the log with `logread -f`.
2015-11-13 12:26:05 +01:00
# Status
2020-11-29 23:43:14 +01:00
This is more of a template than something standalone, but I use it for
my home routers as is. You most
2015-11-13 12:26:05 +01:00
probably want to customize this script here and there; search for
`CUSTOMIZE` for places of interest.
2015-11-15 16:51:42 +01:00
Most importantly, **set up a password and maybe an ssh key**.
2015-11-13 12:26:05 +01:00
2021-10-19 14:27:15 +02:00
At the time of writing it only supports a few `ath79` routers out of
2023-03-10 14:16:58 +01:00
the box, where support merely means that it can flash some leds in the
initial setup phase as a feedback mechanism. It's easy to extend it,
just look up and add some hw specific led names in
`setLedAttribute`. Everything else should work fine without this, but
it will be less convenient to interact with your router in the initial
setup phase.
# Troubleshooting
2016-01-01 14:55:53 +01:00
## Which file should I flash?
2022-09-19 10:39:19 +02:00
You should consult the [OpenWrt documentation](https://openwrt.org/docs/guide-user/start).
2020-11-29 23:43:14 +01:00
The produced firmware files should be somewhere around
2021-10-19 14:27:15 +02:00
```./build/openwrt-imagebuilder-21.02.0-ath79-generic.Linux-x86_64/bin/targets/ath79/generic/```.
2016-01-01 14:55:53 +01:00
In short:
* You need a file with the name ```-factory.bin``` or ```-sysupgrade.bin```. The former is to
2022-09-19 10:39:19 +02:00
be used when you first install OpenWrt, the latter is when you upgrade an already installed
OpenWrt.
2016-01-01 14:55:53 +01:00
* You must carefully pick the proper firmware file for your **hardware version**! I advise you
2022-09-19 10:39:19 +02:00
to look up the wiki page for your hardware on the [OpenWrt wiki](https://openwrt.org),
because most of them have a table of the released hardware versions with comments on their
2022-09-19 10:39:19 +02:00
status (sometimes new hardware revisions are only supported by the latest OpenWrt, which is
2016-01-01 14:55:53 +01:00
not released yet).
2016-03-17 14:59:39 +01:00
## Help! The build has finished but there's no firmware file!
2016-01-01 14:55:53 +01:00
If the build doesn't yield a firmware file (```*-factory.bin``` and/or ```*-sysupgrade.bin```):
when there's not enough space in the flash memory of the target device to install everything
2022-09-19 10:39:19 +02:00
then the OpenWrt ImageBuilder prints a hardly visible error into its flow of output and
2016-01-01 14:55:53 +01:00
silently continues. Look into [build.sh](build.sh#L31) and try to remove some packages
that you can live without.
2022-09-19 10:39:44 +02:00
## Extroot is not mounted after a `sysupgrade`
2023-03-10 14:16:58 +01:00
In short, this is an OpenWrt issue, and the solution is to mount the extroot
somewhere, and delete `/etc/.extroot-uuid`. More details are available in
2022-09-19 10:39:44 +02:00
[this issue](https://github.com/attila-lendvai/openwrt-auto-extroot/issues/12),
and a way to deal with it can be found in
[this blog post](https://blog.mbirth.de/archives/2014/05/26/openwrt-sysupgrade-with-extroot.html).
You may also want to check out the
[official OpenWrt wiki](https://openwrt.org/docs/guide-user/additional-software/extroot_configuration#system_upgrade)
on this topic.