These files are for using the OpenWrt build system to build kplex for OpenWrt.
kplex is a program for combining and routing NMEA-0183 data to and from multiple sources and destinations. By installing it on a USB-enabled router, it is possible to broadcast NMEA data over a local ethernet and/or wifi network, making the data available to computers, phones, and tablets connected to the network.
For more information about kplex see http://www.stripydog.com/kplex/.
To run kplex on your router, it must be compiled for your router's architecture. Rather than compiling software on the router directly, as we would on most computers, it is normal to use a process called cross-compiling whereby the software is compiled on a more powerful machine, but with your router's architecture as the target.
Fortunately, OpenWrt makes cross-compiling software very easy, using the OpenWrt SDK which is pre-compiled for every supported architecture, saving you from having to build the whole system from scratch using the OpenWrt Buildroot.
Please note that these instructions assume a certain amount of familiarity with the command line.
-
Install the prerequisites required to run the OpenWrt build system.
This depends on your system. The requirements are the same as for the Buildroot and are listed here.
The following will normally be sufficient:$ sudo apt-get update $ sudo apt-get install git build-essential ccache libssl-dev libncurses5-dev unzip gawk zlib1g-dev
-
Download and unpack the OpenWrt SDK.
You can find the SDK for your router's architecture from the OpenWrt downloads page. The SDK download you need is found in the same directory as the firmware for your router.
For example, the OpenWrt 15.05.1 SDK for the commonar71xx
architecture is found here. -
Set up the SDK.
cd
into the extractedSDK
directory and execute the following command:$ make menuconfig
A menu-based interface will appear. Choose the
<Exit>
option, then choose to<Save>
the generated config.
-
Ensure you are in the root
SDK
directory. -
Clone this repo into the
package/kplex
subdir:$ git clone https://github.com/caesar/kplex-openwrt.git package/kplex
-
Use
make
to build thepackage/kplex/compile
target:$ make package/kplex/compile
This will download the source code for kplex, cross-compile it for your router, and package it in an IPKG installer package.
The package will be located in the
bin
subdirectory of the SDK. For my architecture the package is atbin/ar71xx/packages/base/kplex_1.3.4-1_ar71xx.ipk
.
-
Copy the package to your router: (change the filename and the IP address of your router as appropriate)
$ scp bin/ar71xx/packages/base/kplex_1.3.4-1_ar71xx.ipk [email protected]:
-
SSH into your router and install the package using OPKG.
You have to runopkg update
first to update the package lists, so that OPKG will know where to download the dependencylibpthreads
.$ ssh [email protected] $ opkg update $ opkg install kplex_1.3.4-1_ar71xx.ipk
The commands above should result in
libpthreads
being downloaded and installed, and then kplex being installed.
If you want to run kplex automatically at startup, run the following command:
$ /etc/init.d/kplex enable
Likewise, to disable it, run:
$ /etc/init.d/kplex disable
If you have the LuCI web interface installed on your router, you can also enable and disable kplex from the System > Startup
page.
The config file for kplex is located at /etc/kplex.conf
.
You must edit this file to tell kplex what you want it to do.
The default config file is empty (all lines are commented out), so by default kplex will do nothing.
For information on the config file syntax see the kplex website.