2014-12-10 02:11:30 +01:00
|
|
|
# What
|
2014-12-03 00:24:22 +01:00
|
|
|
|
2018-06-26 23:25:24 +02:00
|
|
|
It's a script to build a customized OpenWRT firmware image on a Linux x86_64 host
|
|
|
|
(basic familiarity with [OpenWRT](https://wiki.openwrt.org/doc/howto/user.beginner)
|
|
|
|
is assumed).
|
2015-05-28 01:34:10 +02:00
|
|
|
|
2016-01-01 14:55:53 +01:00
|
|
|
If the generated image is flashed on a device it will try to automatically
|
2015-05-28 01:34:10 +02:00
|
|
|
set up [extroot](http://wiki.openwrt.org/doc/howto/extroot) on **any
|
|
|
|
(!)** storage device plugged into the USB port (`/dev/sda`). 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
|
|
|
|
### Building
|
2014-12-10 02:11:30 +01:00
|
|
|
|
2017-04-21 03:09:09 +02:00
|
|
|
To build it, issue the following command: `./build.sh architecture variant device-profile`, e.g.:
|
2018-06-25 10:39:28 +02:00
|
|
|
* `./build.sh ar71xx generic tl-wr1043nd-v2`
|
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
|
|
|
|
2018-06-25 10:39:28 +02:00
|
|
|
If you want to change which OpenWRT version is used, then edit the relevant variable(s) 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
|
|
|
|
2015-11-13 12:26:05 +01:00
|
|
|
Once it booted into the new extroot, it will continuously attempt to install
|
2018-06-25 10:39:28 +02:00
|
|
|
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
|
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).
|
|
|
|
|
2018-06-25 10:39:28 +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
|
|
|
|
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, but it should still work without that.
|
2015-07-11 04:17:18 +02:00
|
|
|
|
|
|
|
# Troubleshooting
|
|
|
|
|
2016-01-01 14:55:53 +01:00
|
|
|
## Which file should I flash?
|
|
|
|
|
2018-06-26 23:25:24 +02:00
|
|
|
You should consult the [OpenWRT documentation](https://wiki.openwrt.org/doc/howto/user.beginner).
|
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
|
2018-06-25 10:39:28 +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
|
|
|
|
to look up the wiki page for your hardware on the [OpenWRT wiki](https://wiki.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
|
2018-06-25 10:39:28 +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
|
2018-06-25 10:39:28 +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.
|