112 lines
4.6 KiB
Markdown
Raw Normal View History

# What
2014-12-03 00:24:22 +01:00
2017-04-21 02:28:41 +02:00
It's a script to build a customized [LEDE](https://lede-project.org/)
firmware image using a Linux x86_64 host (basic familiarity with
[LEDE](https://lede-project.org/) is assumed). LEDE is a fork of
[OpenWRT](https://openwrt.org/).
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.
# 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.
2015-11-13 12:26:05 +01:00
# How
### Building
To build issue the following command: `./build.sh architecture variant device-profile`, e.g.:
2017-04-21 02:28:41 +02:00
* `./build.sh ar71xx generic tl-wdr4300-v1`
2017-04-21 02:28:41 +02:00
Results will be under `build/lede-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.
2017-04-21 02:28:41 +02:00
If you want to change which LEDE 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
2015-11-13 12:26:05 +01:00
At the first boot after flashing the firmware 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
2017-04-21 02:28:41 +02:00
some LEDE packages until an internet connection is set up on the router
2015-11-15 16:51:42 +01:00
(either by using ssh or LuCI if you could fit it into the firmware).
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).
2017-04-21 02:28:41 +02:00
If a password is set, then telnet is disabled by LEDE 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
This is more of a template than something standalone. You most
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
I've extracted this from a project of mine where OpenWRT nodes auto-provision
themselves in 3 stages (stage 3 was a Python script for an app-level sync feature),
but I thought it's useful enough for making it public.
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,
2015-11-13 12:26:05 +01:00
but it's easy to extend it.
2015-11-13 12:26:05 +01:00
## Tested with
2017-04-21 02:28:41 +02:00
[LEDE 17.01.1](https://downloads.lede-project.org/releases/17.01.1/)
2015-11-13 12:26:05 +01:00
on a TP-Link WDR4300.
# Troubleshooting
2016-01-01 14:55:53 +01:00
## Which file should I flash?
2017-04-21 02:28:41 +02:00
You should consult the documentation at [LEDE](https://lede-project.org/docs/start) and/or at
[OpenWRT](https://wiki.openwrt.org/doc/howto/user.beginner).
The produced firmware files should be somewhere around ```build/lede-imagebuilder-17.01.1-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
2017-04-21 02:28:41 +02:00
be used when you first install LEDE, the latter is when you upgrade an already installed
LEDE.
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),
because most of them have a table of the released hardawre versions with comments on their
2017-04-21 02:28:41 +02:00
status (sometimes new hardware revisions are only supported by the latest LEDE, 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
2017-04-21 02:28:41 +02:00
then the LEDE 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.