A feed in OpenWrt is a collection of packages which share a common location. Feeds may reside on a remote server, in a version control system, on the local filesystem, or in any other location addressable by a single name (path/URL) over a protocol with a supported feed method.
Feeds are additional predefined package build recipies for OpenWrt Buildroot.
The list of usable feeds is configured from the
feeds.conf file (or
feeds.conf does not exist). This file contains a list of feeds, one per line, and any number of empty lines. Comments begin with # and extend to the end of a line and are ignored during parsing. Each feed line consists of 3 whitespace-separated components: The feed method, the feed name, and the feed source.
As of this writing, the following methods are supported:
|src-bzr|| Data is downloaded from the source path/URL using
|src-cpy||Data is copied from the source path|
|src-darcs|| Data is downloaded from the source path/URL using
|src-git|| Data is downloaded from the source path/URL using
|src-hg|| Data is downloaded from the source path/URL using
|src-link||A symlink to the source path is created|
|src-svn|| Data is downloaded from the source path/URL using
Feed names are used to identify feeds and serve as the basis for several file and directory names that are created to hold information about the feeds. The feed source is the location from which the feed data is downloaded.
For the methods listed above which rely on version control systems that support a “limited history” option (such as
bzr) the smallest available history is downloaded. This is a good default, but developers who are actively committing to a feed and/or using the commit history may want to change this behavior. This can be done by editing
scripts/feeds appropriately or by checking out the feed without using
Feeds can be utilized through the
scripts/feeds script. A list of the available commands is generated by invoking
scripts/feeds without any arguments. Most commands require the feed information to be available locally, so running update first is usually necessary. In the following discussion the term “applicable packages” usually refers to the package names given on the command line or all packages in a feed when the -a option is used.
The clean command removes the locally stored feed data, including the feed indexes and data for all packages in the feed (but not the symlinks created by the install command, which will be dangling until the feeds are re-downloaded by the update command). This is done by removing the
feeds directory and all subdirectories.
The install command installs the applicable packages and any packages on which the applicable packages depend (both direct dependencies and build dependencies). The installation process consists of creating a symbolic link from
feeds/$feed_name/$package_name so that the package will be included in the configuration process when the directory hierarchy under
packages is searched.
|./scripts/feeds install -a||Install all packages (not recommended, only install the packages you need)|
|./scripts/feeds install luci||Install only the package LuCI|
|./scripts/feeds install -a -p luci||Install the LuCI WebUI|
|Please note that this replaces the old method of creating symlinks, which can be still found on-line in many old forum and user-group entries|
The list command reads and displays the list of packages in each feed from the index file for the applicable feeds. The index file is stored in the
feeds directory with the name of the feed suffixed with
.index. The file is generated by the update command.
The search command reads through the feed metadata and lists packages which match the given search criteria.
The uninstall command does the opposite of the install command (although it does not address dependent packages in any way). It simply removes any symlinks to the package from the subdirectories of
scripts/feeds update is invoked, each of the applicable feeds are downloaded from their source location into a subdirectory of
feeds with the feed name. It then parses the package information from the feed into an index file used by the list and search commands.
|./scripts/feeds update packages luci||Checkout the packages and luci feeds|
Note that update also stores the configured location of the feed in
feeds/$feed_name.tmp/location such that changes to the configuration can be detected and handled appropriately.
After retrieval the downloaded packages need to be “installed”. Only after installation will they be available in the configuration interface!
Ok, you've developed your package, and now you want to use it via make menuconfig, OR you are developing a package and you want to test it in a build before you try to get it included in OpenWrt.
The solution is a custom feed. You can either create an entirely new feed, or use a modified version of one of the standard ones.
For this example we assume that your are in
/home/user/openwrt as your base directory.
svn co svn:svn.openwrt.org/openwrt/trunk openwrt(for the packages feed)
(for the OpenWRT base system) -svn co svn:svn.openwrt.org/openwrt/packages packages
cp packagedir /home/user/openwrt/project/customfeed/), so that your package is under (in this example)
or in the case of the second example:
./scripts/feeds update customfeed
./scripts/feeds install -p customfeed
The downloaded sources (referenced in package Makefiles) are not there… The downloads go first to <buildroot>/dl as gzipped .gz files. And there they are stored and then they get unzipped to /build_dir, I think (or to staging_dir ?) See e.g. <buildroot>/build_dir/target-mips_r2_uClibc-0.9.32 and below it you will find subdirectories for each package's sources.