120 lines
5.1 KiB
Markdown
Raw Normal View History

# What
2014-12-03 00:24:22 +01:00
It's a script to build a customized OpenWRT firmware image on a Linux x86_64 host
(basic familiarity with [OpenWRT](https://openwrt.org/docs/guide-user/start)
is assumed).
2015-05-28 01:34:10 +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)
on **any (!)** storage device plugged into the USB port (`/dev/sda`). Keep in
2015-05-28 01:34:10 +02:00
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
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)
page, and the page that lists some other
[ImageBuilder frontends](https://openwrt.org/docs/guide-developer/imagebuilder_frontends).
As for the actual mechanism: custom scripts are baked into the firmware that are
hidden by the successfully mounted extroot; i.e. they will only run when the extroot
has failed to mount properly.
2015-11-13 12:26:05 +01:00
### Building
2017-04-21 03:09:09 +02:00
To build it, issue the following command: `./build.sh architecture variant device-profile`, e.g.:
* `./build.sh ar71xx generic tl-wr1043nd-v2`
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.
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
2015-11-13 12:26:05 +01:00
Once it booted into the new extroot, it will continuously attempt to install
some OpenWRT packages until an internet connection is set up on the router
2017-04-21 03:09:09 +02:00
(either by using ssh or the web UI (LuCI)).
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).
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
2015-11-15 16:51:42 +01:00
At the time of writing it only supports a few `ar71xx` routers out of the box,
2020-11-29 23:43:14 +01:00
but it's easy to extend it. Support for a new router entails looking up
some led names for setLedAttribute for the user feedback 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.
# Troubleshooting
2016-01-01 14:55:53 +01:00
## Which file should I flash?
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
```build/openwrt-imagebuilder-17.01.4-ar71xx-generic.Linux-x86_64/bin/ar71xx```.
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
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
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
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
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.