openwrtv4/target/linux/uml
John Crispin 994e5ce2f9 kernel: update 3.10.36->3.10.44
205-fix-headers_install.patch is obseleted by upstream commit 3246a0352e3d58380b9386570f1db1faf7edf8a8

Signed-off-by: John Crispin <blogic@openwrt.org>

SVN-Revision: 41351
2014-06-26 13:47:42 +00:00
..
base-files/etc uml: work-around console issue with procd 2013-09-24 13:36:33 +00:00
config Update UML target to 3.10 and various improvements 2014-06-12 17:57:19 +00:00
image
patches-3.10 Update UML target to 3.10 and various improvements 2014-06-12 17:57:19 +00:00
Makefile kernel: update 3.10.36->3.10.44 2014-06-26 13:47:42 +00:00
README target/uml: update README 2014-02-18 22:16:04 +00:00

Openwrt inside a user mode linux.  Why would we even want this many ask?

There are potentially a lot of reasons, one obvious one to me, it allows
folks to 'kick the tires' without actually flashing up any hardware.  It's
also a great environment for porting over packages, you can get a package
fully functional in the uclibc root environment inside a uml without actually
disturbing your 'real router', and then rebuild for a specific target once
it's fully tested.

This is a first stab at a build that 'just works' and there will be more
cleanup to come.  The simple directions are:-

Configure for uml target
Configure with an ext4 root file system
build it all

In your bin directory you will find a kernel and an ext4 root file system
when it's finished.  Just run it like this:-

bin/uml/openwrt-uml-vmlinux ubd0=bin/uml/openwrt-uml-ext4.img

The uml will start, and eventually the serial console of the uml will be at your
console prompt.  If you would like it in xterms, substitute con=xterm and con0=xterm.
No networking is configured, but, it's a starting point.  The resulting file system
has just enough free space to start kicking the tires and playing in the world of
'embedded routers' along with all the resource restrictions that come with that
world.  

To configure networking and more, refer to the user mode linux documentation online.
A quick start goes along this line.  install the uml-utilities packages so you have
the uml switch in and running, then add a command param to your uml start like this

eth0=daemon,00:01:01:01:01:01,unix,/<your uml switch control socket here>

With that in, and uml networking actually functional (can be a challenge at times),
you should be able to ifconfig the interface and talk to the host side, or, if you
bridged the uml switch to your host network, you should be able to run udhcp and be
away with networking off to the world.  Again, if you are unfamiliar with uml and
uml networking, please read the docs and how-to stuff available on the net.  It does
take some fiddling to get it started and working right the first time, but after that,
it opens up a whole new world of virtual machines.



http://user-mode-linux.sourceforge.net/