2014-12-10 02:11:30 +01:00
|
|
|
# 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
|
2020-12-03 21:16:01 +01:00
|
|
|
[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.
|
2014-12-10 02:11:30 +01:00
|
|
|
|
|
|
|
# Why
|
|
|
|
|
2015-11-13 12:26:05 +01:00
|
|
|
So that e.g. customers can buy a router on their own, flash our custom
|
2014-12-10 02:11:30 +01:00
|
|
|
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
|
2020-12-03 21:16:01 +01:00
|
|
|
|
2022-09-19 10:39:19 +02:00
|
|
|
You can read more about the underlying technology on the OpenWrt wiki: see e.g. the
|
2020-12-03 21:16:01 +01:00
|
|
|
[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
|
2020-12-03 21:16:01 +01:00
|
|
|
[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.
|
2020-12-03 21:16:01 +01:00
|
|
|
|
2015-11-13 12:26:05 +01:00
|
|
|
### Building
|
2014-12-10 02:11:30 +01:00
|
|
|
|
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`
|
2022-02-28 13:53:55 +01:00
|
|
|
* `./build.sh bcm53xx generic dlink_dir-885l`
|
2014-12-10 02:11:30 +01:00
|
|
|
|
2018-06-25 10:18:37 +02:00
|
|
|
Results will be under `build/openwrt-imagebuilder-${release}-${architecture}-${variant}.Linux-x86_64/bin/`.
|
2014-12-10 02:11:30 +01:00
|
|
|
|
2017-04-21 02:28:41 +02:00
|
|
|
To see a list of available targets, run `make info` in the ImageBuilder dir.
|
2016-07-25 14:34:32 +02:00
|
|
|
|
2022-09-19 10:39:19 +02:00
|
|
|
If you want to change which OpenWrt version is used, then edit the relevant variable(s)
|
2020-12-03 21:16:01 +01:00
|
|
|
in `build.sh`.
|
2014-12-10 02:11:30 +01:00
|
|
|
|
2015-11-15 16:51:42 +01:00
|
|
|
### Setup stages
|
2014-12-10 02:11:30 +01:00
|
|
|
|
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).
|
2014-12-10 02:11:30 +01:00
|
|
|
|
2015-11-15 16:51:42 +01:00
|
|
|
#### Stage 1: setup extroot
|
2014-12-10 02:11:30 +01:00
|
|
|
|
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.
|
2014-12-10 02:11:30 +01:00
|
|
|
|
2015-11-15 16:51:42 +01:00
|
|
|
#### Stage 2: download and install some packages from the internet
|
2014-12-10 02:11:30 +01:00
|
|
|
|
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
|
2014-12-10 02:11:30 +01:00
|
|
|
|
|
|
|
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).
|
2014-12-10 02:11:30 +01:00
|
|
|
|
|
|
|
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
|
|
|
|
the box, but it's easy to extend it. Support for a new router entails
|
|
|
|
looking up some led names for `setLedAttribute` so that there's
|
|
|
|
feedback to the user through the blinking of the leds. It should work
|
|
|
|
fine without that, but it will be less convenient to interact with
|
|
|
|
your router in the initial setup phase.
|
2015-07-11 04:17:18 +02:00
|
|
|
|
|
|
|
# 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),
|
2018-06-26 23:25:24 +02:00
|
|
|
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`
|
|
|
|
|
|
|
|
In short, this is an OpenWrt issue. The longer discussion is available in
|
|
|
|
[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.
|