<?xml version="1.0" encoding="utf-8" ?>

<rss version="2.0" 
   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
   xmlns:admin="http://webns.net/mvcb/"
   xmlns:dc="http://purl.org/dc/elements/1.1/"
   xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
   xmlns:wfw="http://wellformedweb.org/CommentAPI/"
   xmlns:content="http://purl.org/rss/1.0/modules/content/"
   >
<channel>
    <title>ixs' Vodkamelone - Hardware</title>
    <link>http://blog.vodkamelone.de/</link>
    <description>rants and raves...</description>
    <dc:language>de</dc:language>
    <admin:errorReportsTo rdf:resource="mailto:" />
    <generator>Serendipity 1.3-beta1 - http://www.s9y.org/</generator>
    
    <image>
        <url>http://blog.vodkamelone.de/templates/default/img/s9y_banner_small.png</url>
        <title>RSS: ixs' Vodkamelone - Hardware - rants and raves...</title>
        <link>http://blog.vodkamelone.de/</link>
        <width>100</width>
        <height>21</height>
    </image>

<item>
    <title>Installing OpenWrt on a Microtik Routerboard RB433</title>
    <link>http://blog.vodkamelone.de/archives/148-Installing-OpenWrt-on-a-Microtik-Routerboard-RB433.html</link>
            <category>Fedora</category>
            <category>Hardware</category>
            <category>Unix</category>
    
    <comments>http://blog.vodkamelone.de/archives/148-Installing-OpenWrt-on-a-Microtik-Routerboard-RB433.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=148</wfw:comment>

    <slash:comments>3</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=148</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;!-- s9ymdb:160 --&gt;&lt;img class=&quot;serendipity_image_left&quot; width=&quot;67&quot; height=&quot;110&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/rb433s.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;&lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/stoile.name/blog/&#039;);&quot;  href=&quot;http://stoile.name/blog/&quot; title=&quot;Dreams and Memories by Philipp Riegger&quot;&gt;A friend of mine&lt;/a&gt; wanted a small embedded linux router. After evaluating several options such as &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.routerboard.com/&#039;);&quot;  href=&quot;http://www.routerboard.com/&quot; title=&quot;Routerboard&quot;&gt;Routerboard&lt;/a&gt;, &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.soekris.com/&#039;);&quot;  href=&quot;http://www.soekris.com/&quot; title=&quot;Soekris Engineering&quot;&gt;Soekris&lt;/a&gt; or &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.pcengines.ch/alix.htm&#039;);&quot;  href=&quot;http://www.pcengines.ch/alix.htm&quot; title=&quot;PC Engines&quot;&gt;ALIX&lt;/a&gt; systems, he decided to get himself a &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/routerboard.com/comparison.html&#039;);&quot;  href=&quot;http://routerboard.com/comparison.html&quot; title=&quot;Routerboard overview&quot;&gt;Microtik Routerboard 433&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;The RB433 is a small MIPS board based on the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.atheros.com/pt/AR7100.htm&#039;);&quot;  href=&quot;http://www.atheros.com/pt/AR7100.htm&quot; title=&quot;Atheros AR7100 Product Brief&quot;&gt;Atheros AR7100 chipset&lt;/a&gt; with a 300MHz CPU, 64MB RAM, 3 100Base-TX ethernet ports and three slots for &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/MiniPCI&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/MiniPCI&quot; title=&quot;MiniPCI @ Wikipedia&quot;&gt;MiniPCI Cards&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;The Routerboard manufacturer &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.mikrotik.com/&#039;);&quot;  href=&quot;http://www.mikrotik.com/&quot; title=&quot;Microtik&quot;&gt;Microtik&lt;/a&gt; delivers these systems with a software called &quot;RouterOS&quot;. I haven&#039;t looked any closer at it but it seems to be Linux based system with some proprietary userspace management applications. RouterOS seems mostly to be just a Nortel-ish command line interface and a &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.urbandictionary.com/define.php?term=fugly&#039;);&quot;  href=&quot;http://www.urbandictionary.com/define.php?term=fugly&quot; title=&quot;Fugly - Fucking Ugly at UrbanDictionary&quot;&gt;fugly&lt;/a&gt; webinterface. Some people claim that RouterOS is kinda nifty, but it&#039;s definitely not hackable enough considering the plans my friend had with his device.&lt;/p&gt;

&lt;p&gt;To solve his dilemma, we did what everyone else does in a similar situation, we put a &lt;i&gt;real&lt;/i&gt; Linux on it:&lt;br /&gt;
OpenWrt to the rescue!&lt;/p&gt;

&lt;h4&gt;Getting to know the Routerboard&lt;/h4&gt;

&lt;p&gt;When connecting the power to the Routerboard, the system beeps after a short time and outputs some status messages to the serial port. In order to read these, one has to connect to the serial port via a &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/Null_modem&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/Null_modem&quot; title=&quot;Null modem cable&quot;&gt;serial crossover cable&lt;/a&gt; and use a terminal program.&lt;/p&gt;

&lt;p&gt;Minicom is one such terminal program. Personally though, I prefer cu from the uucp package as it is rather lightweight. All one has to type is &lt;i&gt;cu -l ttyS0 -s 115200&lt;/i&gt; and the bootup messages from the routerboard connected to COM1 will be visible. If you&#039;re using any other terminal program, the console settings are the usual 115200bps, &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/8-N-1&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/8-N-1&quot; title=&quot;8n1 at Wikipedia&quot;&gt;8 data bits, No parity bits and 1 stop bit&lt;/a&gt;.&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
RouterBOOT booter 2.15

RouterBoard 433

Authorization: Passed
CPU frequency: 300 MHz
  Memory size:  64 MB

Press any key within 2 seconds to enter setup

&lt;/pre&gt;
&lt;p&gt;Now is a good time to press any key to enter the setup mode in order to see what the device can do.&lt;br /&gt;
You&#039;ll be presented with the following screen:&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
RouterBOOT-2.15
What do you want to configure?
   d - boot delay
   k - boot key
   s - serial console
   o - boot device
   u - cpu mode
   f - cpu frequency
   r - reset booter configuration
   e - format nand
   g - upgrade firmware
   i - board info
   p - boot protocol
   x - exit setup
your choice: 
&lt;/pre&gt;

&lt;p&gt;Change the bootmode to tell the device _not_ to boot from the local flash chip (called NAND) but from the network. To do that, press &quot;o&quot; and &quot;e&quot;.&lt;br /&gt;
Afterwards press &quot;x&quot; to leave the setup.&lt;br /&gt;
The device will try to boot and get its kernel from the network.&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
RouterBOOT booter 2.15

RouterBoard 433

Authorization: Passed
CPU frequency: 300 MHz
  Memory size:  64 MB

Press any key within 2 seconds to enter setup
trying dhcp protocol...........................................................
kernel loading failed
&lt;/pre&gt;

&lt;p&gt;So it seems the device is looking for a kernel.&lt;br /&gt;
Let&#039;s build one for it to boot sucessfully from...&lt;/p&gt;

&lt;h4&gt;Building OpenWrt Kamikaze&lt;/h4&gt;

&lt;p&gt;In order to correctly install the OpenWrt system a linux host is needed to build the kernel image on. I&#039;ve been using &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/fedoraproject.org/en/get-fedora&#039;);&quot;  href=&quot;http://fedoraproject.org/en/get-fedora&quot; title=&quot;Get Fedora&quot;&gt;Fedora 9&lt;/a&gt; from the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/fedoraproject.org/&#039;);&quot;  href=&quot;http://fedoraproject.org/&quot; title=&quot;Fedora Project&quot;&gt;Fedora Project&lt;/a&gt; which did the job perfectly. Any other recent distribution should work equally well.&lt;/p&gt;

&lt;p&gt;First, check out the current development code via &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/Subversion_(software)&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/Subversion_(software)&quot; title=&quot;Subversion Versioning System&quot;&gt;Subversion&lt;/a&gt; to have the greatest and latest code:
&lt;pre class=&quot;screen&quot;&gt;
[athienem@localhost ~]$ mkdir ~/openwrt
[athienem@localhost ~]$ cd ~/openwrt
[athienem@localhost openwrt]$ svn co https://svn.openwrt.org/openwrt/trunk/
[...]
Updated to revision 13193.
[athienem@localhost openwrt]$ 
&lt;/pre&gt;

&lt;p&gt;In order to install the system correctly we&#039;ll be needing two different OpenWrt images:&lt;br /&gt;
One image is a &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/JFFS2&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/JFFS2&quot; title=&quot;JFFS2 at Wikipedia&quot;&gt;JFFS2&lt;/a&gt; or &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/SquashFS&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/SquashFS&quot; title=&quot;SquashFS&quot;&gt;SquashFS&lt;/a&gt; image to install onto the target device.&lt;br /&gt;
The other image is the so called ramdisk image which can be booted over the network and contains a minimal shell. This image will be used to install the JFFS2 or SquashFS image onto the device and will never again be used. Think of it as a &quot;rescue image&quot;.&lt;/p&gt;

&lt;p&gt;Both images are basically built the same way.&lt;br /&gt;
First, change to the svn checkout directory called trunk and execute &lt;i&gt;make menuconfig&lt;/i&gt; to configure the OpenWrt image.&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
[athienem@localhost openwrt]$ cd trunk/
[athienem@localhost trunk]$ make menuconfig
&lt;/pre&gt;

&lt;p&gt;This command will start the ncurses interface to generate a .config file. It should look familiar to people having built kernels before.&lt;br /&gt;
Make sure that &quot;Atheros AR71xx [2.6]&quot; is selected as the target system:&lt;br /&gt;
&lt;!-- s9ymdb:162 --&gt;&lt;img class=&quot;serendipity_image_center&quot; width=&quot;722&quot; height=&quot;433&quot; style=&quot;border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/menuconfig.png&quot; alt=&quot;&quot;  /&gt;&lt;br /&gt;
This will make sure that the resulting kernel is bootable on the Routerboard 433.&lt;/p&gt;

&lt;p&gt;The next step is to select the target image format, chose ramdisk for now:&lt;br /&gt;
&lt;!-- s9ymdb:163 --&gt;&lt;img class=&quot;serendipity_image_center&quot; width=&quot;721&quot; height=&quot;432&quot; style=&quot;border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/ramdisk.png&quot; alt=&quot;&quot;  /&gt;&lt;br /&gt;
Now select &amp;quot;&amp;lt; Exit &amp;gt;&amp;quot; in the main menu and confirm that you want to save your new OpenWrt configuration.&lt;/p&gt;

&lt;p&gt;The next step is to actually build the image by calling &quot;make 
&lt;pre class=&quot;screen&quot;&gt;
*** End of OpenWrt configuration.
*** Execute &#039;make&#039; to build the OpenWrt or try &#039;make help&#039;.
[athienem@localhost trunk]$ make
Checking &#039;working-make&#039;... ok.
Checking &#039;case-sensitive-fs&#039;... ok.
Checking &#039;working-gcc&#039;... ok.
Checking &#039;working-g++&#039;... ok.
Checking &#039;ncurses&#039;... ok.
Checking &#039;zlib&#039;... ok.
Checking &#039;gawk&#039;... ok.
Checking &#039;bison&#039;... ok.
Checking &#039;flex&#039;... ok.
Checking &#039;unzip&#039;... ok.
Checking &#039;bzip2&#039;... ok.
Checking &#039;patch&#039;... ok.
Checking &#039;perl&#039;... ok.
Checking &#039;wget&#039;... ok.
Checking &#039;gnutar&#039;... ok.
Checking &#039;autoconf&#039;... ok.
Checking &#039;non-root&#039;... ok.
Collecting target info: done
Collecting package info: done
Checking &#039;bison&#039;... ok.
Checking &#039;automake&#039;... ok.
&lt;span style=&quot;color: chocolate;&quot;&gt; make[2] tools/install&lt;/span&gt;
[...]
&lt;span style=&quot;color: chocolate;&quot;&gt; make[2] target/install
 make[3] -C target/linux install
 make[2] package/index&lt;/span&gt;
[athienem@localhost trunk]$ 
&lt;/pre&gt;

&lt;p&gt;Everything went fine and there should be a ramdisk image in elf format:
&lt;pre class=&quot;screen&quot;&gt;
[athienem@localhost trunk]$ ls -all bin/openwrt-ar71xx-vmlinux-initramfs.elf 
-rwxrwxr-x 1 athienem athienem 3735060 2008-11-13 22:27 &lt;span style=&quot;color: green;&quot;&gt;bin/openwrt-ar71xx-vmlinux-initramfs.elf&lt;/span&gt;
[athienem@localhost trunk]$ 
&lt;/pre&gt;

&lt;p&gt;The next step is to build the system image to be installed on the device. Execute &lt;i&gt;make menuconfig&lt;/i&gt; again but this time select either squashfs or jffs2 as the target image format instead of ramdisk:
&lt;!-- s9ymdb:164 --&gt;&lt;img class=&quot;serendipity_image_center&quot; width=&quot;720&quot; height=&quot;434&quot; style=&quot;border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/squashfs.png&quot; alt=&quot;&quot;  /&gt;&lt;br /&gt;
After saving the config, execute &lt;i&gt;make&lt;/i&gt; again. This time, it should be much faster as nearly everything is already compiled.&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
#
# using defaults found in .config
#


*** End of OpenWrt configuration.
*** Execute &#039;make&#039; to build the OpenWrt or try &#039;make help&#039;.

[athienem@localhost trunk]$ make
++ mkdir -p /home/athienem/openwrt/trunk/staging_dir/toolchain-mips_gcc4.1.2
++ cd /home/athienem/openwrt/trunk/staging_dir/toolchain-mips_gcc4.1.2
++ mkdir -p bin lib include stamp
&lt;span style=&quot;color: chocolate;&quot;&gt; make[1] world&lt;/span&gt;
[...]
&lt;span style=&quot;color: chocolate;&quot;&gt; make[2] target/install
 make[3] -C target/linux install
 make[2] package/index&lt;/span&gt;
[athienem@localhost trunk]$ 
&lt;/pre&gt;

&lt;p&gt;Now the &lt;i&gt;bin/&lt;/i&gt; directory should be filled with some files:&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
[athienem@localhost trunk]$ ls -all bin/
total 23656
drwxrwxr-x  3 athienem athienem    4096 2008-11-08 18:25 &lt;span style=&quot;color: navy;&quot;&gt;.&lt;/span&gt;
drwxrwxr-x 15 athienem athienem    4096 2008-11-13 22:44 &lt;span style=&quot;color: navy;&quot;&gt;..&lt;/span&gt;
-rw-rw-r--  1 athienem athienem     710 2008-11-13 22:46 md5sums
-rw-rw-r--  1 athienem athienem 1499367 2008-11-08 18:25 &lt;span style=&quot;color: maroon;&quot;&gt;openwrt-ar71xx-rootfs.tgz&lt;/span&gt;
-rw-rw-r--  1 athienem athienem 1441792 2008-11-08 18:25 openwrt-ar71xx-root.squashfs
-rw-rw-r--  1 athienem athienem 2492740 2008-11-13 22:46 &lt;span style=&quot;color: maroon;&quot;&gt;openwrt-ar71xx-uImage.gz&lt;/span&gt;
-rwxrwxr-x  1 athienem athienem 2248838 2008-11-08 18:25 &lt;span style=&quot;color: green;&quot;&gt;openwrt-ar71xx-vmlinux.bin&lt;/span&gt;
-rwxrwxr-x  1 athienem athienem 2258096 2008-11-08 18:25 &lt;span style=&quot;color: green;&quot;&gt;openwrt-ar71xx-vmlinux.elf&lt;/span&gt;
-rw-rw-r--  1 athienem athienem 1048576 2008-11-08 18:25 &lt;span style=&quot;color: maroon;&quot;&gt;openwrt-ar71xx-vmlinux.gz&lt;/span&gt;
-rwxrwxr-x  1 athienem athienem 3725815 2008-11-13 22:46 &lt;span style=&quot;color: green;&quot;&gt;openwrt-ar71xx-vmlinux-initramfs.bin&lt;/span&gt;
-rwxrwxr-x  1 athienem athienem 3735072 2008-11-13 22:46 &lt;span style=&quot;color: green;&quot;&gt;openwrt-ar71xx-vmlinux-initramfs.elf&lt;/span&gt;
-rw-rw-r--  1 athienem athienem 2555904 2008-11-13 22:46 &lt;span style=&quot;color: maroon;&quot;&gt;openwrt-ar71xx-vmlinux-initramfs.gz&lt;/span&gt;
-rw-rw-r--  1 athienem athienem 2293760 2008-11-13 22:46 &lt;span style=&quot;color: maroon;&quot;&gt;openwrt-ar71xx-vmlinux-initramfs.lzma&lt;/span&gt;
-rw-rw-r--  1 athienem athienem  786432 2008-11-08 18:25 &lt;span style=&quot;color: maroon;&quot;&gt;openwrt-ar71xx-vmlinux.lzma&lt;/span&gt;
drwxrwxr-x  3 athienem athienem    4096 2008-11-08 17:50 &lt;span style=&quot;color: navy;&quot;&gt;packages&lt;/span&gt;
[athienem@localhost trunk]$ 
&lt;/pre&gt;

&lt;h4&gt;Booting OpenWrt on the RouterBoard&lt;/h4&gt;

&lt;p&gt;To boot the routerboard, a dhcp server is needed to tell the bootloader on the Routerboard which IP address it should use and where to get it&#039;s bootable kernel image.&lt;br /&gt;
The tftp server is needed to actually serve said image to the RouterBoard.&lt;/p&gt;

&lt;p&gt;Under Fedora linux, installing both just needs the command &lt;i&gt;yum install -y dhcp tftp-server&lt;/i&gt;. To activate both services, chkconfig can be used as root:&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
[root@localhost ~]# chkconfig dhcpd on
[root@localhost ~]# chkconfig tftp on
&lt;/pre&gt;

&lt;p&gt;The configuration for the dhcpd needs to be adapted to the local circumstances. The setup I&#039;ve been using was a crosslinked cable between the notebook and the Routerboard with a manually configured IP address of 192.168.23.254/24. All that is configured in that file is to assign the RouterBoard an IP address and tell it to boot the file vmlinux. Adapt the following file as needed for your own circumstances:&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
[root@localhost ~]# cat /etc/dhcpd.conf 
# Global Parameters

authoritative;

max-lease-time 604800;
default-lease-time 3100;

ddns-update-style none;
ddns-ttl 7200;

allow booting;
allow bootp;
one-lease-per-client true;

subnet 192.168.23.0 netmask 255.255.255.0 {
	option routers 192.168.23.254;
	option subnet-mask 255.255.255.0;
	option broadcast-address 192.168.23.255;
	ignore client-updates;
}

group {
	host routerboard {
		hardware ethernet 00:0c:42:32:43:8a;
		next-server 192.168.23.254;
		fixed-address 192.168.23.2;
		filename &quot;vmlinux&quot;;
	}

}
[root@localhost ~]# 
&lt;/pre&gt;

&lt;p&gt;Start the dhcp server by calling &lt;i&gt;service dhcpd start&lt;/i&gt;, if there are any problems, look into &lt;i&gt;/var/log/messages&lt;/i&gt; and fix the issues noted there.&lt;/p&gt;

&lt;p&gt;The tftp-server has already been activated earlier but might need a &lt;i&gt;service xinetd restart&lt;/i&gt; to be really started. Do that.&lt;br /&gt;
Then copy the ramdisk image named &lt;i&gt;openwrt-ar71xx-vmlinux-initramfs.elf&lt;/i&gt; to the tftproot. This is &lt;i&gt;/tftpboot&lt;/i&gt; on older systems or &lt;i&gt;/var/lib/tftpboot/&lt;/i&gt; on newer systems. Name the copied file vmlinux.&lt;/p&gt;

&lt;p&gt;If everything is working fine, the system should boot:&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
RouterBOOT booter 2.15

RouterBoard 433

Authorization: Passed
CPU frequency: 300 MHz
  Memory size:  64 MB

Press any key within 2 seconds to enter setup...

trying dhcp protocol... OK
resolved mac address 00:1C:23:03:AA:F8
Gateway: 192.168.23.254
transfer started ............................ transfer ok, time=1.68s
setting up elf image... OK
jumping to kernel code
Linux version 2.6.26.7 (athienem@localhost.localdomain) (gcc version 4.1.2) #1 Sat Nov 8 18:11:40 CET 2008
console [early0] enabled
CPU revision is: 00019374 (MIPS 24K)
Determined physical RAM map:
 memory: 04000000 @ 00000000 (usable)
Initrd not found or empty - disabling initrd
Zone PFN ranges:
  Normal          0 -&gt;    16384
Movable zone start PFN for each node
early_node_map[1] active PFN ranges
    0:        0 -&gt;    16384
Built 1 zonelists in Zone order, mobility grouping on.  Total pages: 16256
Kernel command line: root=/dev/mtdblock2 rootfstype=squashfs,yaffs,jffs2 noinitrd console=ttyS0,115200 init=/etc/preinit
Primary instruction cache 64kB, VIPT, 4-way, linesize 32 bytes.
Primary data cache 32kB, 4-way, VIPT, cache aliases, linesize 32 bytes
Writing ErrCtl register=000227c0
Readback ErrCtl register=000227c0
PID hash table entries: 256 (order: 8, 1024 bytes)
Dentry cache hash table entries: 8192 (order: 3, 32768 bytes)
Inode-cache hash table entries: 4096 (order: 2, 16384 bytes)
Memory: 60768k/65536k available (1762k kernel code, 4700k reserved, 312k data, 1572k init, 0k highmem)
SLUB: Genslabs=6, HWalign=32, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
Mount-cache hash table entries: 512
net_namespace: 484 bytes
NET: Registered protocol family 16
MIPS: machine is MikroTik RouterBOARD 433/AH
registering PCI controller with io_map_base unset
PCI: mapping irq 33 to pin1@0000:00:13.0
NET: Registered protocol family 2
IP route cache hash table entries: 1024 (order: 0, 4096 bytes)
TCP established hash table entries: 2048 (order: 2, 16384 bytes)
TCP bind hash table entries: 2048 (order: 1, 8192 bytes)
TCP: Hash tables configured (established 2048 bind 2048)
TCP reno registered
NET: Registered protocol family 1
squashfs: version 3.0 (2006/03/15) Phillip Lougher
Registering mini_fo version $Id$
JFFS2 version 2.2. (NAND) (SUMMARY)  © 2001-2006 Red Hat, Inc.
yaffs Nov  8 2008 18:08:56 Installing. 
msgmni has been set to 118
io scheduler noop registered
io scheduler deadline registered (default)
Serial: 8250/16550 driver $Revision: 1.90 $ 1 ports, IRQ sharing disabled
serial8250.0: ttyS0 at MMIO 0x18020000 (irq = 11) is a 16550A
console handover: boot [early0] -&gt; real [ttyS0]
ag71xx_mdio: probed
eth0: Atheros AG71xx at 0xba000000, irq 5
eth1: Atheros AG71xx at 0xb9000000, irq 4
NAND flash driver for RouterBoard 4xx series version 0.1.10
NAND SPI clock 25000 kHz (AHB 150000 kHz / 6)
FLASH SPI clock 25000 kHz (AHB 150000 kHz / 6)
NAND device: Manufacturer ID: 0xad, Chip ID: 0x76 (Hynix NAND 64MiB 3,3V 8-bit)
Scanning device for bad blocks
Bad eraseblock 828 at 0x00cf0000
Creating 3 MTD partitions on &quot;NAND 64MiB 3,3V 8-bit&quot;:
0x00000000-0x00040000 : &quot;booter&quot;
0x00040000-0x00400000 : &quot;kernel&quot;
0x00400000-0x04000000 : &quot;rootfs&quot;
mtd: partition &quot;rootfs&quot; set to be root filesystem
split_squashfs: no squashfs found in &quot;NAND 64MiB 3,3V 8-bit&quot;
Atheros AR71xx SPI Controller driver version 0.2.2
Atheros AR71xx hardware watchdog driver version 0.1.0
Registered led device: rb4xx:yellow:user
TCP vegas registered
NET: Registered protocol family 17
802.1Q VLAN Support v1.8 Ben Greear &lt;greearb@candelatech.com&gt;
All bugs added by David S. Miller &lt;davem@redhat.com&gt;
Freeing unused kernel memory: 1572k freed
Algorithmics/MIPS FPU Emulator v1.5
[sighandler]: No more events to be processed, quitting.
[cleanup]: Waiting for children.
[cleanup]: All children terminated.
- preinit -
Press CTRL-C for failsafe

Please press Enter to activate this console. br-lan: Dropping NETIF_F_UFO since no NETIF_F_HW_CSUM feature.
device eth0 entered promiscuous mode
PPP generic driver version 2.4.2
ip_tables: (C) 2000-2006 Netfilter Core Team
nf_conntrack version 0.5.0 (1024 buckets, 4096 max)
wlan: trunk
ath_hal: module license &#039;Proprietary&#039; taints kernel.
ath_hal: 2008-10-02 (AR5210, AR5211, AR5212, AR5416, RF5111, RF5112, RF2413, RF5413, RF2133, RF2425, REGOPS_FUNC, DFS, XR)
ath_rate_minstrel: Minstrel automatic rate control algorithm 1.2 (trunk)
ath_rate_minstrel: look around rate set to 10%
ath_rate_minstrel: EWMA rolloff level set to 75%
ath_rate_minstrel: max segment size in the mrr set to 6000 us
wlan: mac acl policy registered
ath_pci: trunk
PCI: Enabling device 0000:00:13.0 (0000 -&gt; 0002)
Atheros HAL provided by OpenWrt, DD-WRT and MakSat Technologies
wifi0: 11a rates: 6Mbps 9Mbps 12Mbps 18Mbps 24Mbps 36Mbps 48Mbps 54Mbps
wifi0: 11b rates: 1Mbps 2Mbps 5.5Mbps 11Mbps
wifi0: 11g rates: 1Mbps 2Mbps 5.5Mbps 11Mbps 6Mbps 9Mbps 12Mbps 18Mbps 24Mbps 36Mbps 48Mbps 54Mbps
wifi0: turboA rates: 6Mbps 9Mbps 12Mbps 18Mbps 24Mbps 36Mbps 48Mbps 54Mbps
wifi0: turboG rates: 6Mbps 12Mbps 18Mbps 24Mbps 36Mbps 48Mbps 54Mbps
wifi0: H/W encryption support: WEP AES AES_CCM TKIP
ath_pci: wifi0: Atheros 5212: mem=0x10000000, irq=33
eth0: link up (100Mbps/Full duplex)
br-lan: port 1(eth0) entering learning state
br-lan: topology change detected, propagating
br-lan: port 1(eth0) entering forwarding state



BusyBox v1.11.2 (2008-11-08 17:55:16 CET) built-in shell (ash)
Enter &#039;help&#039; for a list of built-in commands.

  _______                     ________        __
 |       |.-----.-----.-----.|  |  |  |.----.|  |_
 |   -   ||  _  |  -__|     ||  |  |  ||   _||   _|
 |_______||   __|_____|__|__||________||__|  |____|
          |__| W I R E L E S S   F R E E D O M
 KAMIKAZE (bleeding edge, r13141) -------------------
  * 10 oz Vodka       Shake well with ice and strain
  * 10 oz Triple sec  mixture into 10 shot glasses.
  * 10 oz lime juice  Salute!
 ---------------------------------------------------
root@OpenWrt:/# 
&lt;/pre&gt;

&lt;p&gt;If something didn&#039;t work out, check your system log to see what happens. Adding the &amp;quot;-s&amp;quot; parameter to the tftpd binary might be useful as it will log single requests.&lt;/p&gt;

&lt;h4&gt;Permanently installing OpenWrt on the RouterBoard&lt;/h4&gt;

&lt;p&gt;As we have an accessible Linux system running now on the RouterBoard the available tools such as scp and mtd can be used to copy the needed files onto the NAND device and thus permanently install OpenWrt on the device.&lt;/p&gt;

&lt;p&gt;Under Linux the NAND device is partitioned and can be accessed through the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.linux-mtd.infradead.org/&#039;);&quot;  href=&quot;http://www.linux-mtd.infradead.org/&quot; title=&quot;Memory Technology Device Framework&quot;&gt;mtd framework&lt;/a&gt; which exports some information to userspace through the &lt;i&gt;/proc&lt;/i&gt; filesystem:
&lt;pre class=&quot;screen&quot;&gt;
root@OpenWrt:/# cat /proc/mtd 
dev:    size   erasesize  name
mtd0: 00040000 00004000 &quot;booter&quot;
mtd1: 003c0000 00004000 &quot;kernel&quot;
mtd2: 03c00000 00004000 &quot;rootfs&quot;
&lt;/pre&gt;

&lt;p&gt;As can easily be seen, there are three &amp;quot;partitions&amp;quot; available. Leave the one called &amp;quot;booter&amp;quot; alone, it might be important and contain the bootloader. I haven&#039;t checked. All we&#039;re interested in is &amp;quot;kernel&amp;quot; and &amp;quot;rootfs&amp;quot;. The former contains the kernel, the latter the root filesystem.&lt;/p&gt;

&lt;p&gt;To install the elf kernel binary named openwrt-ar71xx-vmlinux.elf, it has to be transferred onto the RouterBoard and written onto the second mtd partition. Make sure that the file is called &lt;i&gt;kernel&lt;/i&gt;.&lt;br /&gt;
&lt;b&gt;Note:&lt;/b&gt; OpenWrt configures its IP address to be 192.168.1.1 on bootup. You might have to change this with &lt;i&gt;ifconfig&lt;/i&gt;.&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
root@OpenWrt:/# scp athienem@192.168.23.254:openwrt/trunk/bin/openwrt-ar71xx-vmlinux.elf /tmp/
root@OpenWrt:/# mount /dev/mtdblock1 /mnt/
yaffs: dev is 32505857 name is &quot;mtdblock1&quot;
yaffs: passed flags &quot;&quot;
yaffs: Attempting MTD mount on 31.1, &quot;mtdblock1&quot;
root@OpenWrt:/# mv /tmp/openwrt-ar71xx-vmlinux.elf /mnt/kernel
root@OpenWrt:/# ls /mnt
kernel      lost+found
root@OpenWrt:/# umount  /mnt/
save exit: isCheckpointed 0
root@OpenWrt:/# 
&lt;/pre&gt;

&lt;p&gt;The kernel image is installed.&lt;br /&gt;
The rootfs is even easier, as the mtd-device does not need to be mounted at all to write the squashfs image called openwrt-ar71xx-root.squashfs in my case.&lt;br /&gt;
This just needs to be written as is onto the mtd block device named rootfs:&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
root@OpenWrt:/# scp athienem@192.168.23.254:openwrt/trunk/bin/openwrt-ar71xx-root.squashfs /tmp/
root@OpenWrt:/# cat /tmp/openwrt-ar71xx-root.squashfs &gt; /dev/mtdblock2
root@OpenWrt:/# 
&lt;/pre&gt;

&lt;p&gt;After a few seconds the squashfs image has been written and the device can be rebooted. Don&#039;t forget to disable the network boot in the Bios:&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;
root@OpenWrt:/# reboot
root@OpenWrt:/# br-lan: port 1(eth0) entering disabled state
device eth0 left promiscuous mode
br-lan: port 1(eth0) entering disabled state
eth0: link down
Restarting system.


RouterBOOT booter 2.15

RouterBoard 433

Authorization: Passed
CPU frequency: 300 MHz
  Memory size:  64 MB

Press any key within 2 seconds to enter setup..

RouterBOOT-2.15
What do you want to configure?
   d - boot delay
   k - boot key
   s - serial console
   o - boot device
   u - cpu mode
   f - cpu frequency
   r - reset booter configuration
   e - format nand
   g - upgrade firmware
   i - board info
   p - boot protocol
   x - exit setup
your choice: 
&lt;/pre&gt;

&lt;p&gt;Press &amp;quot;o&amp;quot; twice and &amp;quot;x&amp;quot; once to continue booting normally from the NAND.&lt;/p&gt;


&lt;pre class=&quot;screen&quot;&gt;
RouterBOOT booter 2.15

RouterBoard 433

Authorization: Passed
CPU frequency: 300 MHz
  Memory size:  64 MB

Press any key within 2 seconds to enter setup..
loading kernel from nand... OK
setting up elf image... OK
jumping to kernel code
Linux version 2.6.26.7 (athienem@localhost.localdomain) (gcc version 4.1.2) #2 Sat Nov 8 18:25:41 CET 2008
console [early0] enabled
CPU revision is: 00019374 (MIPS 24K)
Determined physical RAM map:
 memory: 04000000 @ 00000000 (usable)
Initrd not found or empty - disabling initrd
Zone PFN ranges:
  Normal          0 -&gt;    16384
Movable zone start PFN for each node
early_node_map[1] active PFN ranges
    0:        0 -&gt;    16384
Built 1 zonelists in Zone order, mobility grouping on.  Total pages: 16256
Kernel command line: root=/dev/mtdblock2 rootfstype=squashfs,yaffs,jffs2 noinitrd console=ttyS0,115200 init=/etc/preinit
Primary instruction cache 64kB, VIPT, 4-way, linesize 32 bytes.
Primary data cache 32kB, 4-way, VIPT, cache aliases, linesize 32 bytes
Writing ErrCtl register=000227c0
Readback ErrCtl register=000227c0
PID hash table entries: 256 (order: 8, 1024 bytes)
Dentry cache hash table entries: 8192 (order: 3, 32768 bytes)
Inode-cache hash table entries: 4096 (order: 2, 16384 bytes)
Memory: 62208k/65536k available (1762k kernel code, 3252k reserved, 312k data, 124k init, 0k highmem)
SLUB: Genslabs=6, HWalign=32, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
Mount-cache hash table entries: 512
net_namespace: 484 bytes
NET: Registered protocol family 16
MIPS: machine is MikroTik RouterBOARD 433/AH
registering PCI controller with io_map_base unset
PCI: mapping irq 33 to pin1@0000:00:13.0
NET: Registered protocol family 2
IP route cache hash table entries: 1024 (order: 0, 4096 bytes)
TCP established hash table entries: 2048 (order: 2, 16384 bytes)
TCP bind hash table entries: 2048 (order: 1, 8192 bytes)
TCP: Hash tables configured (established 2048 bind 2048)
TCP reno registered
NET: Registered protocol family 1
squashfs: version 3.0 (2006/03/15) Phillip Lougher
Registering mini_fo version $Id$
JFFS2 version 2.2. (NAND) (SUMMARY)  © 2001-2006 Red Hat, Inc.
yaffs Nov  8 2008 18:08:56 Installing. 
msgmni has been set to 121
io scheduler noop registered
io scheduler deadline registered (default)
Serial: 8250/16550 driver $Revision: 1.90 $ 1 ports, IRQ sharing disabled
serial8250.0: ttyS0 at MMIO 0x18020000 (irq = 11) is a 16550A
console handover: boot [early0] -&gt; real [ttyS0]
ag71xx_mdio: probed
eth0: Atheros AG71xx at 0xba000000, irq 5
eth1: Atheros AG71xx at 0xb9000000, irq 4
NAND flash driver for RouterBoard 4xx series version 0.1.10
NAND SPI clock 25000 kHz (AHB 150000 kHz / 6)
FLASH SPI clock 25000 kHz (AHB 150000 kHz / 6)
NAND device: Manufacturer ID: 0xad, Chip ID: 0x76 (Hynix NAND 64MiB 3,3V 8-bit)
Scanning device for bad blocks
Bad eraseblock 828 at 0x00cf0000
Creating 3 MTD partitions on &quot;NAND 64MiB 3,3V 8-bit&quot;:
0x00000000-0x00040000 : &quot;booter&quot;
0x00040000-0x00400000 : &quot;kernel&quot;
0x00400000-0x04000000 : &quot;rootfs&quot;
mtd: partition &quot;rootfs&quot; set to be root filesystem
split_squashfs: no squashfs found in &quot;NAND 64MiB 3,3V 8-bit&quot;
Atheros AR71xx SPI Controller driver version 0.2.2
Atheros AR71xx hardware watchdog driver version 0.1.0
Registered led device: rb4xx:yellow:user
TCP vegas registered
NET: Registered protocol family 17
802.1Q VLAN Support v1.8 Ben Greear &lt;greearb@candelatech.com&gt;
All bugs added by David S. Miller &lt;davem@redhat.com&gt;
VFS: Mounted root (squashfs filesystem) readonly.
Freeing unused kernel memory: 124k freed
Please be patient, while OpenWrt loads ...
Algorithmics/MIPS FPU Emulator v1.5
- preinit -
Press CTRL-C for failsafe
- init -

Please press Enter to activate this console. br-lan: Dropping NETIF_F_UFO since no NETIF_F_HW_CSUM feature.
device eth0 entered promiscuous mode
PPP generic driver version 2.4.2
ip_tables: (C) 2000-2006 Netfilter Core Team

nf_conntrack version 0.5.0 (1024 buckets, 4096 max)
wlan: trunk
ath_hal: module license &#039;Proprietary&#039; taints kernel.
ath_hal: 2008-10-02 (AR5210, AR5211, AR5212, AR5416, RF5111, RF5112, RF2413, RF5413, RF2133, RF2425, REGOPS_FUNC, DFS, XR)
ath_rate_minstrel: Minstrel automatic rate control algorithm 1.2 (trunk)
ath_rate_minstrel: look around rate set to 10%
ath_rate_minstrel: EWMA rolloff level set to 75%
ath_rate_minstrel: max segment size in the mrr set to 6000 us
wlan: mac acl policy registered
eth0: link up (100Mbps/Full duplex)
br-lan: port 1(eth0) entering learning state
br-lan: topology change detected, propagating
br-lan: port 1(eth0) entering forwarding state
ath_pci: trunk
PCI: Enabling device 0000:00:13.0 (0000 -&gt; 0002)
Atheros HAL provided by OpenWrt, DD-WRT and MakSat Technologies
wifi0: 11a rates: 6Mbps 9Mbps 12Mbps 18Mbps 24Mbps 36Mbps 48Mbps 54Mbps
wifi0: 11b rates: 1Mbps 2Mbps 5.5Mbps 11Mbps
wifi0: 11g rates: 1Mbps 2Mbps 5.5Mbps 11Mbps 6Mbps 9Mbps 12Mbps 18Mbps 24Mbps 36Mbps 48Mbps 54Mbps
wifi0: turboA rates: 6Mbps 9Mbps 12Mbps 18Mbps 24Mbps 36Mbps 48Mbps 54Mbps
wifi0: turboG rates: 6Mbps 12Mbps 18Mbps 24Mbps 36Mbps 48Mbps 54Mbps
wifi0: H/W encryption support: WEP AES AES_CCM TKIP
ath_pci: wifi0: Atheros 5212: mem=0x10000000, irq=33



BusyBox v1.11.2 (2008-11-08 17:55:16 CET) built-in shell (ash)
Enter &#039;help&#039; for a list of built-in commands.

  _______                     ________        __
 |       |.-----.-----.-----.|  |  |  |.----.|  |_
 |   -   ||  _  |  -__|     ||  |  |  ||   _||   _|
 |_______||   __|_____|__|__||________||__|  |____|
          |__| W I R E L E S S   F R E E D O M
 KAMIKAZE (bleeding edge, r13141) -------------------
  * 10 oz Vodka       Shake well with ice and strain
  * 10 oz Triple sec  mixture into 10 shot glasses.
  * 10 oz lime juice  Salute!
 ---------------------------------------------------
root@OpenWrt:/# 
&lt;/pre&gt;

&lt;p&gt;Done.&lt;/p&gt;

&lt;p&gt;OpenWrt has been installed on the device and can be used and configured as usual.&lt;/p&gt;
&lt;p&gt;For more information about configuring, using and customizing OpenWrt see the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/downloads.openwrt.org/kamikaze/docs/openwrt.html&#039;);&quot;  href=&quot;http://downloads.openwrt.org/kamikaze/docs/openwrt.html&quot; title=&quot;OpenWrt Kamikaze Manual&quot;&gt;Kamikaze Manual&lt;/a&gt;, the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/wiki.openwrt.org&#039;);&quot;  href=&quot;http://wiki.openwrt.org&quot; title=&quot;OpenWrt Wiki&quot;&gt;OpenWrt Wiki&lt;/a&gt; or use the source. For network related configuration issues, &lt;i&gt;/lib/network/config.sh&lt;/i&gt; and the files in &lt;i&gt;/lib/wifi/&lt;/i&gt; are a good start. 
    </content:encoded>

    <pubDate>Thu, 13 Nov 2008 23:56:00 +0100</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/148-guid.html</guid>
    
</item>
<item>
    <title>Unbricking an Intel Pro/1000 (e1000) network interface</title>
    <link>http://blog.vodkamelone.de/archives/146-Unbricking-an-Intel-Pro1000-e1000-network-interface.html</link>
            <category>Bawue.Net</category>
            <category>Fedora</category>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/146-Unbricking-an-Intel-Pro1000-e1000-network-interface.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=146</wfw:comment>

    <slash:comments>2</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=146</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;!-- s9ymdb:152 --&gt;&lt;img class=&quot;serendipity_image_left&quot; width=&quot;110&quot; height=&quot;110&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/e1000.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;As most readers of this blog are probably aware, pre-releases of the Linux Kernel 2.6.27 are able to trash the NVRAM/EEPROM of certain Intel Network cards. As usual, lwn.net has &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/lwn.net/Articles/300202/&#039;);&quot;  href=&quot;http://lwn.net/Articles/300202/&quot;&gt;a nice writeup&lt;/a&gt; of the issue including some background information.&lt;br /&gt;
I had a similar problem in the past and as a favour for some friends of mine, I&#039;ve written down a small description to restoring the ethernet firmware in these cards. This guide should serve as a good primer on reflashing your broken nic but probably needs to be adapted for your own use case.&lt;/p&gt;

&lt;p&gt;NB: Instead of just giving a command by command description of what I did, I&#039;ll try explaining a bit more about the background and the process of fixing the problem at hand. Maybe this gives other people some insight into valuable problem solving skills.&lt;/p&gt;

&lt;p&gt;Some years back we bought quite some &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.tyan.com/archive/products/html/tomcati7210.html&#039;);&quot;  href=&quot;http://www.tyan.com/archive/products/html/tomcati7210.html&quot; title=&quot;Tyan S5112 Tomcat i7210&quot;&gt;Tyan S5112 machines&lt;/a&gt; for &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.bawue.net&#039;);&quot;  href=&quot;http://www.bawue.net&quot; title=&quot;Baden-Württembergs nichtkommerzieller Internetprovider&quot;&gt;bawue.net&lt;/a&gt;.&lt;br /&gt;
The idea was to fit these machines with the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.tyan.com/archive/products/html/m3289.html&#039;);&quot;  href=&quot;http://www.tyan.com/archive/products/html/m3289.html&quot; title=&quot;m3289 Server Management Daughter Card&quot;&gt;Tyan m3289 server management card&lt;/a&gt;, an &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/IPMI&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/IPMI&quot; title=&quot;Intelligent Platform Management Interface at Wikipedia&quot;&gt;IPMI&lt;/a&gt; card allowing remotely powercycling of the machines and offering a serial console via the network.&lt;/p&gt;

&lt;p&gt;In order to have the whole setup work, the IPMI management module needs support from the network interface in order to receive IP packets while the machine is powered off. After contacting the Tyan support, we were offered a firmware file to flash into the network adapter activating the needed &amp;quot;management mode&amp;quot;. This firmware file came in the form of a .bin file and an accompanying eeupdate.exe file for flashing the firmware image.&lt;/p&gt;

&lt;p&gt;The mainboard has two ethernet controllers, with the 82547EI one being the controller utilized by the management card. The lspci output on this board looks as follows:
&lt;pre class=&quot;screen&quot;&gt;[root@selene ~]# lspci|grep Ethernet
01:01.0 Ethernet controller: Intel Corporation 82547EI Gigabit Ethernet Controller
03:02.0 Ethernet controller: Intel Corporation 82541GI Gigabit Ethernet Controller
[root@selene ~]#&lt;/pre&gt;
&lt;/p&gt;

&lt;p&gt;The instructions for flashing the firmware were relatively simple: Boot with a DOS bootdisk and execute &lt;i&gt;eeupdate -nic=1 -d 82547EI.eep&lt;/i&gt;&lt;br /&gt;
After I pressed enter, nothing much happened. The system wasn&#039;t reading anything from the disk, there was no progress message on the screen, just the general start-message of the firmware update tool.&lt;/p&gt;

&lt;p&gt;When nothing happened after 5 minutes of waiting, I foolishly reset the system. &lt;b&gt;Big mistake!&lt;/b&gt;.&lt;/p&gt;

&lt;p&gt;On the next boot of the system, there were no PXE messages from the network card and during bootup the e1000 linux driver only threw out the ominous message &lt;i&gt;The EEPROM Checksum Is Not Valid&lt;/i&gt; without loading the network interface.&lt;br /&gt;
It turns out, I just trashed the firmware of my on-board network interface.&lt;br /&gt;
Calling the eeupdate program again did not work as it bailed out because the eeprom was corrupted&lt;br /&gt;
At such times, I firmly believe in the use of swearwords accompanied by heavy googling for some advice. Alas, googling told me only that I broke my hardware and needed new one.&lt;/p&gt;

&lt;p&gt;As returning hardware because of a problem is akin to giving up, which is generally unacceptable, I decided to look into the issue a bit more and find a workable solution to unbrick the network interface.&lt;br /&gt;
To recap, I had the following:
&lt;ul&gt;
 &lt;li&gt;One on-board network interface with a corrupted nvram&lt;/li&gt;
 &lt;li&gt;One eeprom image for said network interface (For reference: &lt;a href=&quot;http://blog.vodkamelone.de/uploads/82547EI.EEP&quot; title=&quot;82547EI.EEP&quot; target=&quot;_blank&quot;&gt;82547EI.EEP&lt;/a&gt;)&lt;/li&gt;
 &lt;li&gt;No working flash program&lt;/li&gt;
 &lt;li&gt;No working driver&lt;/li&gt;
 &lt;li&gt;One working Linux system without network&lt;/li&gt;
 &lt;li&gt;One working Linux notebook with network&lt;/li&gt;
&lt;/ul&gt;
Luckily, the working Linux system and network access is all I needed:&lt;/p&gt;

&lt;p&gt;The first step was getting the sources of the e1000 driver from the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/sourceforge.net/projects/e1000&#039;);&quot;  href=&quot;http://sourceforge.net/projects/e1000&quot; title=&quot;e1000 at sf.net&quot;&gt;project page&lt;/a&gt;. As this was a few years ago, I chose the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/downloads.sourceforge.net/e1000/e1000-7.3.15.tar.gz?modtime=1161336542&amp;amp;amp;big_mirror=0&#039;);&quot;  href=&quot;http://downloads.sourceforge.net/e1000/e1000-7.3.15.tar.gz?modtime=1161336542&amp;amp;big_mirror=0&quot; title=&quot;e1000 Linux driver, version 7.3.15&quot;&gt;version 7.3.15&lt;/a&gt; which was current at this time.&lt;/p&gt;

&lt;p&gt;After untaring the sources, a quick &lt;i&gt;grep -R &#039;The EEPROM Checksum Is Not Valid&#039; e1000-7.3.15&lt;/i&gt; turned up one hit in &lt;i&gt;e1000-7.3.15/src/e1000_main.c&lt;/i&gt;:

[geshi lang=c]
        /* make sure the EEPROM is good */

        if (e1000_validate_eeprom_checksum(&amp;adapter-&gt;hw) &lt; 0) {
                DPRINTK(PROBE, ERR, &quot;The EEPROM Checksum Is Not Valid\n&quot;);
                err = -EIO;
                goto err_eeprom;
        }
[/geshi]
So there is a function called &lt;i&gt;e1000_validate_eeprom_checksum&lt;/i&gt; responsible for checking the validity of the eeprom. During the main initialization of the card this function is called and in case the checksum is not valid, the error handler err_eeprom is executed which aborts the module load.&lt;br /&gt;
On a hunch, I removed the whole check logic containted in this function located in &lt;/i&gt;e1000-7.3.15/src/e1000_hw.c&lt;/i&gt;. After I was done, the whole function body consisted only of a &quot;return 0&quot; statement meaning that the checksum check will always succeed.&lt;/p&gt;

&lt;p&gt;Building the modified module by calling &lt;i&gt;make&lt;/i&gt; in the src dir resulted in a e1000.ko file which could be loaded into the running kernel by executing &quot;insmod ./e1000&quot;. (Note, this will probably not work with current kernels as the buildscripts have changed. Use a current version of the e1000 driver instead.)&lt;br /&gt;
To my great relief the driver returned the following message:
&lt;pre class=&quot;screen&quot;&gt;Intel(R) PRO/1000 Network Driver - version 7.3.15
Copyright (c) 1999-2006 Intel Corporation.
e1000: 0000:01:01.0: e1000_probe: (PCI:33MHz:32-bit) ff:ff:ff:ff:ff:ff
e1000: eth0: e1000_probe: Intel(R) PRO/1000 Network Connection
e1000: 0000:03:02.0: e1000_probe: (PCI:33MHz:32-bit) 00:e0:81:55:f2:01
e1000: eth1: e1000_probe: Intel(R) PRO/1000 Network Connection&lt;/pre&gt;
So even though the mac address of the card is broken, at least the card is somewhat detected and I can work on restoring the eeprom.&lt;/p&gt;

&lt;p&gt;For modifying low-level settings of network interfaces under Linux one can usually use the fabulous &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/sourceforge.net/projects/gkernel/&#039;);&quot;  href=&quot;http://sourceforge.net/projects/gkernel/&quot; title=&quot;kernel related software&quot;&gt;ethtool&lt;/a&gt; utility.&lt;br /&gt;
Using the -e parameter dumps the eeprom values of the specified network interface onto the screen. This is great for getting a backup of the eeprom:
&lt;pre class=&quot;screen&quot;&gt;[root@selene ~]# ethtool -e eth1 | head -n 5
Offset		Values
------		------
0x0000		00 e0 81 55 f2 01 10 02 ff ff 06 20 ff ff ff ff 
0x0010		ff ff ff ff 0b 64 76 10 86 80 76 10 86 80 84 b2 
0x0020		dd 20 22 22 00 00 90 2f 80 23 12 00 20 1e 12 00 
[root@selene ~]# &lt;/pre&gt;
&lt;/p&gt;

&lt;p&gt;Even better is the -E parameter as it allows changing a single byte at a specified address in the eeprom:
&lt;pre class=&quot;screen&quot;&gt;[root@selene ~]# ethtool -E eth0 magic 0x10198086 offset 0x0 value 0x00
[root@selene ~]# &lt;/pre&gt;
This command would change the byte at the address 0x0 (the first byte) into the value 0x00. The 0x10198086 value is the &quot;magic&quot; value needed to &quot;unlock&quot; this write operation. Depending on the driver and the card this value is different for each system. In the case of the intel e1000 driver, the magic value is the Device ID and Vendor ID of the selected network card. This value can be gathered by examining the lspci -n output.&lt;/br&gt;
As I was in a hurry back then to get the machine working again, I didn&#039;t try to find out what exactly the magic value was but just commented out this check in the e1000_ethtool.c file.&lt;br /&gt;
For reference, the patch of my modifications to the e1000 driver are &lt;a href=&quot;http://blog.vodkamelone.de/uploads/e1000-repair.patch&quot; title=&quot;e1000-repair.patch&quot; target=&quot;_blank&quot;&gt;e1000-repair.patch&lt;/a&gt;downloadable as a unified diff.
&lt;/p&gt;

&lt;p&gt;Now, that I could change single values in the eeprom, it was time to take a look at the Tyan provided eeprom file:
&lt;pre class=&quot;screen&quot;&gt;[root@localhost root]# head -n 5 82547.eep 
E000 2A81 0855 0A10 FFFF FFFF FFFF FFFF 
FFFF FFFF 640B 1019 8086 1019 8086 B200 
1F35 002A 0E00 0012 0E00 20DD 7777 1F95 
0001 1F73 0098 1F72 3FB0 0009 1200 3649 
00CF 8FA7 290E 0305 0CCA FFFF FFFF FFFF 
&lt;/pre&gt;
Comparing this eeprom file with the dump taken earlier from the second network interface in the machine showed that the .eep file from intel was in &quot;&lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/Little_Endian#Middle-endian&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/Little_Endian#Middle-endian&quot; title=&quot;Endianess at Wikipedia&quot;&gt;mixed-endian&lt;/a&gt;&quot; format, meaning I had to shuffle the values around a bit before being able to rewrite the image. The file contains the eeprom values as groups of two bytes each in reversed order. The first four byte-values in the file are &lt;i&gt;0xe0 0x00 0x2a 0x81&lt;/i&gt; while in the eeprom they would be &lt;i&gt;0x00 0xe0 0x81 0x2a&lt;/i&gt;.&lt;/p&gt;

&lt;p&gt;After I found the correct byte ordering, I could simply call ethtool -E manually with the correct addresses and just write each byte into the eeprom or automate this and reduce the possibility of mistakes. Naturally, automation it is. Back then I chose to do this script in PHP as a small exercise in command-line-interface programming.&lt;br /&gt;

The PHP script can be downloaded as &lt;a href=&quot;http://blog.vodkamelone.de/uploads/eepromer.phps&quot; title=&quot;eepromer.php&quot; target=&quot;_blank&quot;&gt;eepromer.php&lt;/a&gt; and executed by calling &lt;i&gt;php eepromer.php&lt;/i&gt; on the shell.&lt;br /&gt;
In order to explain it&#039;s working, the code is printed below:
[geshi lang=php]&lt;?php
$file = &quot;82547.eep&quot;;

$handle = fopen($file, &quot;r&quot;);
$contents = fread($handle, filesize($file));
fclose($handle);

$tok = strtok($contents, &quot; \n\r&quot;);
$eepdata = &quot;&quot;;

$i = 0;
while ($tok !== false) {
	$eepdata .= substr($tok, 2,2).&#039; &#039;;
	$eepdata .= substr($tok, 0,2).&#039; &#039;;
	$tok = strtok(&quot; \n\r&quot;);
	$i++;
}

$tok = strtok($eepdata, &quot; &quot;);
$i = 0;
while ($tok !== false) {
	$offset = sprintf(&quot;%x&quot;, $i);
	echo &quot;ethtool -E eth0 magic 0x00 offset 0x$offset value 0x$tok\n&quot;;
	$tok = strtok(&quot; &quot;);
	$i++;
}
?&gt;[/geshi]
At the start, the variable file contains the filename to read in. This file is then opened and read into memory as it is only 6K large. The &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/php.net/manual/en/function.strtok.php&#039;);&quot;  href=&quot;http://php.net/manual/en/function.strtok.php&quot; title=&quot;String Tokenizer&quot;&gt;PHP String Tokenizer function&lt;/a&gt; is used to extract the values from the script and the bytes in each extracted group are then swapped around to put them into big endian byte-order. When the eeprom file has been completely parsed the ethtool commands to write the gathered data into the eeprom are printed to STDOUT:
&lt;pre class=&quot;screen&quot;&gt;[root@localhost root]# php eepromer.php | head -n 5
ethtool -E eth0 magic 0x00 offset 0x0 value 0x00
ethtool -E eth0 magic 0x00 offset 0x1 value 0xE0
ethtool -E eth0 magic 0x00 offset 0x2 value 0x81
ethtool -E eth0 magic 0x00 offset 0x3 value 0x2A
ethtool -E eth0 magic 0x00 offset 0x4 value 0x55
[root@localhost root]# &lt;/pre&gt;
By piping the output of this quick-and-dirty script into a shell (php eepromer.php | sh), the content of the .eep file is written for real into the eeprom. The last step is changing the first 6 bytes of the eeprom (offset 0x0 to 0x5) to the original mac address of the network interface.&lt;/br&gt;
After this has been done, the network card is considered repaird or unbricked.&lt;/p&gt;

&lt;p&gt;Now, this explanation should give anyone some hints on fixing his network card&#039;s eeprom should this be needed because of problems with the kernel releases mentioned in the beginning. It is unlikely that following the procedure above to the letter is going to have any usable results as every system and situation is different.&lt;br /&gt;
The major problem would be, that not everyone has a working .eep file from Intel available after his own card is trashed. My suggestion would be to look for a friend who has exactly the same card. This can be achieved by using lspci:
&lt;pre class=&quot;screen&quot;&gt;[root@selene ~]# lspci | grep Ethernet
01:01.0 Ethernet controller: Intel Corporation 82547EI Gigabit Ethernet Controller
03:02.0 Ethernet controller: Intel Corporation 82541GI Gigabit Ethernet Controller
[root@selene ~]# lspci -n | grep &#039;01:01\.0&#039;
01:01.0 0200: 8086:1019
[root@selene ~]# &lt;/pre&gt;
If a friend has the same network card as indicated by the Vendor and Device ID (8086 == Intel, 1019 == 82547EI Gigabit Ethernet Controller in my example) he should be able to take eeprom dump by calling ethtool -e [device] &gt; /tmp/eeprom-[device].dump.:
&lt;pre class=&quot;screen&quot;&gt;[root@selene ~]# ethtool -e eth0 | head -n 8
Offset		Values
------		------
0x0000		00 e0 81 55 f2 00 10 0a ff ff ff ff ff ff ff ff 
0x0010		ff ff ff ff 0b 64 19 10 86 80 19 10 86 80 00 b2 
0x0020		35 1f 2a 00 00 0e 12 00 00 0e dd 20 77 77 95 1f 
0x0030		01 00 73 1f 98 00 72 1f b0 3f 09 00 00 12 49 36 
0x0040		cf 00 a7 8f 0e 29 05 03 c8 0c ff ff ff ff ff ff 
0x0050		ff ff ff ff ff ff ff ff ff ff ff ff ff ff 02 06 
[root@selene ~]# &lt;/pre&gt;
&lt;/p&gt;

&lt;p&gt;This dump file can then be written into your own nvram by an easier procedure then described above. After all, no endianness swapping is necessary as ethtool already returned the data correctly. A bit of reformatting of the import is necessary however but can be accomplished in a simple bash script:
[geshi lang=bash]magic=0x0
j=0
for i in `sed -e &#039;1,2d&#039; /tmp/eeprom-[device].dump | cut -c 9- | tr -d &quot;\n&quot;`
do
    echo ethtool -E magic $magic offset 0x$(printf %x ${j}) value 0x${i}
    j=$(($j + 1))
done
[/geshi]
This script, which can be written as one single line, will remove the header and other superfluous data from the dumpfile, leaving only the values itself which are then echoed to STDOUT in the form of an ethtool command.
&lt;pre class=&quot;screen&quot;&gt;[root@selene ~]# magic=0x0; j=0; for i in `sed -e &#039;1,2d&#039; /tmp/eeprom-[device].dump | cut -c 9- |
tr -d &quot;\n&quot;`; do echo ethtool -E magic $magic offset 0x$(printf %x ${j}) value 0x${i}; j=$(($j + 1)); done | head -n 5
ethtool -E magic 0x0 offset 0x0 value 0x00
ethtool -E magic 0x0 offset 0x1 value 0xe0
ethtool -E magic 0x0 offset 0x2 value 0x81
ethtool -E magic 0x0 offset 0x3 value 0x55
ethtool -E magic 0x0 offset 0x4 value 0xf2
[root@selene ~]#&lt;/pre&gt;
Piping this into a shell will restore your eeprom meaning only the mac address has to be reverted to the old one.
The correct working of the above bash line should be tested however, as the output of ethtool differs depending on the card and the driver.
&lt;/p&gt;

&lt;p&gt;Should the network interface not even be visible on the PCI bus anymore (possible due to the usage of the ibautil.exe tool mentioned on some webpages) reflashing the main bios might work for some systems. The &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.coreboot.org/Flashrom&#039;);&quot;  href=&quot;http://www.coreboot.org/Flashrom&quot; title=&quot;Flashrom&quot;&gt;flashrom utility&lt;/a&gt; from the coreboot project might come in handy for this.&lt;br /&gt;
Otherwise it might be necessary to rewrite the necessary part of the eeprom first through the SPI, a serial programming interface, in order to have it enumerate again on the pci bus.&lt;br /&gt;
Should this be the case, it might be easier to just return your mainboard for repair though.&lt;br /&gt;
Should you be willing however, to try your luck and certainly void any little bit of warranty you had left, Intel offers a nice &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/download.intel.com/design/network/applnots/ap496.pdf&#039;);&quot;  href=&quot;http://download.intel.com/design/network/applnots/ap496.pdf&quot; title=&quot;Intel I/O Controller Hub 8 LAN NVM Map and Information Guide&quot;&gt;manual explaining the firmware format&lt;/a&gt; of it&#039;s ICH8 system.&lt;/p&gt; 
    </content:encoded>

    <pubDate>Thu, 16 Oct 2008 23:23:31 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/146-guid.html</guid>
    
</item>
<item>
    <title>lm_sensors on an ASUS Pundit-R350</title>
    <link>http://blog.vodkamelone.de/archives/142-lm_sensors-on-an-ASUS-Pundit-R350.html</link>
            <category>Fedora</category>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/142-lm_sensors-on-an-ASUS-Pundit-R350.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=142</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=142</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;I&#039;ve recently started to unpack some of the boxes from my last move. In there I found an older Booksize PC, an &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.asus.com/products.aspx?modelmenu=1&amp;amp;amp;model=571&amp;amp;amp;l1=1&amp;amp;amp;l2=3&amp;amp;amp;l3=0&#039;);&quot;  href=&quot;http://www.asus.com/products.aspx?modelmenu=1&amp;amp;model=571&amp;amp;l1=1&amp;amp;l2=3&amp;amp;l3=0&quot; title=&quot;ASUS Product Page&quot;&gt;ASUS Pundid-R350&lt;/a&gt;. It&#039;s not the nicest system I&#039;ve ever had, the fan is incredibly noisy and it&#039;s constantly switching to full speed when the system is loaded. I guess I should swap the fan for something much quieter, but haven&#039;t had the time yet.&lt;/p&gt;

&lt;p&gt;It took me some time to figure out the correct settings to have lm_sensors running on the device as there&#039;s been no template configuration to be found on google. To rectify this omission, I&#039;m dumping mine on my blog:&lt;/p&gt;

&lt;pre&gt;# Asus Pundit-R350
chip &quot;it8712-&amp;lowast;&quot;

# Voltage monitors as advised in the It8705 data sheet

    label in0 &quot;VCore 1&quot;
    label in2 &quot;+3.3V&quot;
    label in3 &quot;+5V&quot;
    label in4 &quot;+12V&quot;

    # Seem not to be connected on the Pundit-R
    ignore in1
    ignore in5
    ignore in6
    ignore in7
    ignore in8
    ignore cpu0_vid

    compute in3 ((6.8/10)+1)&amp;lowast;@ ,  @/((6.8/10)+1)
    compute in4 ((30/10) +1)&amp;lowast;@  , @/((30/10) +1)

# Set some upper and lower limits

    set in0_min 1.4 &amp;lowast; 0.95
    set in0_max 1.4 &amp;lowast; 1.05
    set in2_min 3.3 &amp;lowast; 0.95
    set in2_max 3.3 &amp;lowast; 1.05
    set in3_min 5.0 &amp;lowast; 0.95
    set in3_max 5.0 &amp;lowast; 1.05
    set in4_min 12 &amp;lowast; 0.95
    set in4_max 12 &amp;lowast; 1.05

# Temperature
    label temp1       &quot;CPU Temp&quot;
    set temp1_type 3
    set   temp1_max   75
    set   temp1_min   15
    label temp2       &quot;M/B Temp&quot;
    set temp2_type 2
    set   temp2_max   55
    set   temp2_min   15
    ignore temp3

# Fans
   set fan1_div 2
   set fan1_min 2500
   ignore fan2
   ignore fan3&lt;/pre&gt;

&lt;p&gt;With this configuration written to &lt;i&gt;/etc/sensors3.conf&lt;/i&gt; the freshly installed fedora 9 system correctly shows some sensible sensor readings:&lt;/p&gt;

&lt;pre class=&quot;screen&quot;&gt;[root@workstation ~]# sensors
it8712-isa-0260
Adapter: ISA adapter
VCore 1:     +1.39 V  (min =  +1.33 V, max =  +1.47 V)
+3.3V:       +3.26 V  (min =  +3.14 V, max =  +3.47 V)
+5V:         +5.00 V  (min =  +4.76 V, max =  +5.24 V)
+12V:       +12.03 V  (min = +11.39 V, max = +12.61 V)
fan1:       3994 RPM  (min = 2657 RPM, div = 2)
CPU Temp:    +65.0°C  (low  = +15.0°C, high = +75.0°C)  sensor = thermal diode
M/B Temp:    +50.0°C  (low  = +15.0°C, high = +55.0°C)  sensor = transistor

[root@workstation ~]# &lt;/pre&gt; 
    </content:encoded>

    <pubDate>Wed, 16 Jul 2008 00:12:37 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/142-guid.html</guid>
    
</item>
<item>
    <title>Nicht nur die T-Com hasst mich...</title>
    <link>http://blog.vodkamelone.de/archives/130-Nicht-nur-die-T-Com-hasst-mich....html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/130-Nicht-nur-die-T-Com-hasst-mich....html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=130</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=130</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;img width=&quot;71&quot; height=&quot;110&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/kabelbrand.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;Nachdem ich ja schon ausgiebig &lt;a href=&quot;http://blog.vodkamelone.de/archives/112-T-Com-hasst-mich.html&quot; &gt;meine Abenteuer mit der T-Com&lt;/a&gt; beklagte, musste ich heute ernüchtert feststellen, dass nicht nur die T-Com mich hasst. Nein, auch Cisco mag mich nicht.&lt;/p&gt;

&lt;p&gt;Heute Nacht wurde der &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/de.wikipedia.org/wiki/Broadband_Remote_Access_Server&#039;);&quot;  href=&quot;http://de.wikipedia.org/wiki/Broadband_Remote_Access_Server&quot;  title=&quot;Access Concentrator/Broadband Remote Access Server bei Wikipedia nachschlagen.&quot;&gt;Access Concentrator&lt;/a&gt; in Stuttgart umgetauscht. Früher war ich an &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/jjaf.de/pppoe/ac/&#039;);&quot;  href=&quot;http://jjaf.de/pppoe/ac/&quot;  title=&quot;BRAS in Deutschland&quot;&gt;STGX42-erx&lt;/a&gt;, einer Juniper Networks E-Series, angeschlossen. Mittlerweile ist es ein Cisco 10000 Router mit der Performance Routing Engine 3.&lt;/p&gt;

&lt;p&gt;Das Ergebnis ist deutlich:
&lt;blockquote&gt;
&lt;pre&gt;
Mar 13 17:37:29 rtr pppd[19032]: pppd 2.4.3 started by root, uid 0
Mar 13 17:37:29 rtr pppd[19032]: Using interface ppp0
Mar 13 17:37:30 rtr pppd[19032]: Connect: ppp0 &lt;--&gt; /dev/pts/0
Mar 13 17:37:30 rtr pppoe[19035]: PPP session is 63082
Mar 13 17:37:31 rtr pppd[19032]: CHAP authentication succeeded
Mar 13 17:37:31 rtr pppd[19032]: local  IP address 91.32.100.35
Mar 13 17:37:31 rtr pppd[19032]: remote IP address 217.0.118.57
Mar 13 17:50:01 rtr pppd[19032]: LCP terminated by peer
Mar 13 17:50:01 rtr pppd[19032]: Connect time 12.5 minutes.
Mar 13 17:50:01 rtr pppoe[19035]: Session 63082 terminated -- received PADT from peer
Mar 13 17:50:01 rtr pppoe[19035]: Sent PADT
Mar 13 17:50:01 rtr pppd[19032]: Sent 39902910 bytes, received 18850825 bytes.
Mar 13 17:50:01 rtr pppd[19032]: Modem hangup
Mar 13 17:50:01 rtr pppd[19032]: Connection terminated.
Mar 13 17:50:02 rtr pppd[19032]: Exit.
&lt;/pre&gt;
&lt;/blockquote&gt;
&lt;/p&gt;

&lt;p&gt;Man sieht also sehr schön, wie es eben nicht geht. :-(&lt;/p&gt;
 &lt;br /&gt;&lt;a href=&quot;http://blog.vodkamelone.de/archives/130-Nicht-nur-die-T-Com-hasst-mich....html#extended&quot;&gt;&quot;Nicht nur die T-Com hasst mich...&quot; vollständig lesen&lt;/a&gt;
    </content:encoded>

    <pubDate>Tue, 13 Mar 2007 18:43:47 +0100</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/130-guid.html</guid>
    
</item>
<item>
    <title>Nur eine schlechte Tat ist eine gute Tat</title>
    <link>http://blog.vodkamelone.de/archives/121-Nur-eine-schlechte-Tat-ist-eine-gute-Tat.html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/121-Nur-eine-schlechte-Tat-ist-eine-gute-Tat.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=121</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=121</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;img width=&quot;66&quot; height=&quot;110&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/s65/siemens-S65.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt; Mission accomplished.&lt;/p&gt;
&lt;p&gt;Damit BENQ nicht allzuviel Freude an der gekauften (&lt;i&gt;SPUCK!&lt;/i&gt;)Siemens Handysparte hat war ich gerade so frei und habe &lt;a href=&quot;http://blog.vodkamelone.de/archives/80-Siemens-S65-Telefoncode-zuruecksetzen.html&quot; &gt;mein gebraucht gekauftes Siemens S65 Mobiltelefon&lt;/a&gt; noch am Tag vor Ablauf der Garantie bzw. Gewährleistung reklamiert. Das Display ist verkratzt, die Taste 0 funktioniert nicht immer auf Anhieb und seit Verleihung meines Telefons letzter Woche fehlt auch die silberne Wippe an der Seite des Telefons auf Displayhöhe.&lt;br /&gt;
Damit es nicht allzuviel Stress bei der Reklamation gibt, noch vorher das Fullbackup eingespielt damit das Vodafone gebrandete Telefon auch in bescheidenem Vodafone Branding zurückkommt.&lt;/p&gt;

&lt;p&gt;Nachdem ich dann auch einen auf überforderter Kunde, der keine Ahnung und hat doch nur noch kurz vor Geschäftsschluss beim vielen Gedräge sein Handy repariert haben will, gemacht habe wurde das Telefon dann auch angenommen und ich kriege in ein paar Tagen ein neues.&lt;br /&gt;
Da war der alte Siemens Vorabtausch Service wesentlich angenehmer und wurde zurecht besonders bei Geschäftskunden sehr geschätzt.&lt;/p&gt;

&lt;p&gt;Sobald das neue Gerät dann da ist, wird es hier ein oder zwei Artikel zum Unbranden und Firmware-Modifizieren zum Abschalten lästiger Features geben.&lt;br /&gt;
Das rote Vodafone Branding ist echt das letzte.&lt;/p&gt; 
    </content:encoded>

    <pubDate>Wed,  3 Jan 2007 20:29:00 +0100</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/121-guid.html</guid>
    
</item>
<item>
    <title>My first hands-on OLPC experience</title>
    <link>http://blog.vodkamelone.de/archives/120-My-first-hands-on-OLPC-experience.html</link>
            <category>CCC</category>
            <category>Fedora</category>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/120-My-first-hands-on-OLPC-experience.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=120</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=120</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;img width=&quot;110&quot; height=&quot;99&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/23c3_logo.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt; At &lt;strike&gt;this&lt;/strike&gt; last year&#039;s &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/events.ccc.de/congress/2006/Home&#039;);&quot;  href=&quot;http://events.ccc.de/congress/2006/Home&quot; &gt;Chaos Communication Congress&lt;/a&gt; in Berlin there was a short presentation about the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.laptop.org&#039;);&quot;  href=&quot;http://www.laptop.org&quot; &gt;One Laptop Per Child&lt;/a&gt; system.&lt;/p&gt;

&lt;p&gt;I couldn&#039;t make the talk itself but managed to take a closer look at the OLPC later on when it was on display at the Wikipedia booth.&lt;br /&gt;
My opinion of the device so far is mixed.&lt;br /&gt;
The software collection looks nice but still a bit rough about the edges.&lt;br /&gt;
The hardware in general definitely looks good. Small, portable and low-power. The display especially is really good looking and offers an enjoyable sharp display. I expected something a bit more low quality after following the &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.manucornet.net/blog/dreamerant/?p=39&#039;);&quot;  href=&quot;http://www.manucornet.net/blog/dreamerant/?p=39&quot; &gt;swizzle mode blog post&lt;/a&gt; by Manu but was positivly surprised.&lt;br /&gt;
The keyboard however sucked!&lt;/p&gt;

&lt;p&gt;I might be spoiled keyboardwise as I&#039;m nearly exclusivly using &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/en.wikipedia.org/wiki/Model_M_Keyboard&#039;);&quot;  href=&quot;http://en.wikipedia.org/wiki/Model_M_Keyboard&quot; &gt;IBM Model M Keyboards&lt;/a&gt; which feature distinct tactile feedback and I really detest the soft keyboards which are generally available today.&lt;/p&gt;
&lt;p&gt;The OLPC keyboard however is something else. I haven&#039;t yet seen such a mushy keyboard in a notebook. The keys are quite flat with a very small keydrop of said 1mm. This would be acceptable if there would be some more resistance when depressing the keys. The BTest-1 System I tried however was so squashy I had to keep looking at the screen to check if the key I pressed actually was pressed.&lt;br /&gt;
In general the keyboard feels rotten which is a pity as the system would otherwise be very neat.&lt;/p&gt; 
    </content:encoded>

    <pubDate>Tue,  2 Jan 2007 18:01:35 +0100</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/120-guid.html</guid>
    
</item>
<item>
    <title>Snom 360 SIP Telefon an einer Elmeg ICT mit VoIP-VPN Modul</title>
    <link>http://blog.vodkamelone.de/archives/115-Snom-360-SIP-Telefon-an-einer-Elmeg-ICT-mit-VoIP-VPN-Modul.html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/115-Snom-360-SIP-Telefon-an-einer-Elmeg-ICT-mit-VoIP-VPN-Modul.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=115</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=115</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;img width=&quot;110&quot; height=&quot;102&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/snom360_angle.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;Ich hatte ja zuvor schon ein wenig über das &lt;a href=&quot;http://blog.vodkamelone.de/archives/103-Zuruecksetzen-eines-Elmeg-VoIP-VPN-Gateway.html&quot;  title=&quot;&quot;&gt;Zurücksetzen eines Elmeg VoIP-VPN Modules&lt;/a&gt; und wie über die &lt;a href=&quot;http://blog.vodkamelone.de/archives/106-Making-your-SIP-Phone-work-with-your-Fedora-Router.html&quot; &gt;NAT-Konfiguration für die Elmeg Anlage&lt;/a&gt; geschrieben.&lt;/p&gt;

&lt;p&gt;Leider ergibt sich noch das unangenehme Problem, dass sich das Snom 360 SIP-Telefon nicht an der Elmeg Anlage anmelden kann. Die Fehlermeldung ist immer die selbe. Auf der Elmeg Telefonanlage findet sich folgende Logmeldung.:
&lt;pre&gt;
iwu: [MSG] SIP: Registration reject:
 sip:810@192.168.1.250, guest 0, expires 60, location 2, cause AUTH REQUIRED
&lt;/pre&gt;
&lt;/p&gt;

&lt;p&gt;Eine genauere Analyse des SIP Verkehrs ergibt, dass das Telefon sich nicht an der Anlage anmelden kann, da die Digest-Authentication Informationen nicht stimmen.

&lt;p&gt;Die Lösung für dieses Problem ist, beim Snom Telefon im &quot;Identitäts Menü&quot; für die entsprechende Leitung im &quot;Sip-Reiter&quot; die Unterstützung für &quot;Langer SIP-Contact (RFC3840)&quot; zu deaktivieren.&lt;/p&gt;

&lt;p&gt;Anschliessend kann sich das Telefon sofort bei der Anlage registrieren.&lt;/p&gt; 
    </content:encoded>

    <pubDate>Tue, 10 Oct 2006 01:14:26 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/115-guid.html</guid>
    
</item>
<item>
    <title>Zurücksetzen eines Elmeg VoIP-VPN Gateway</title>
    <link>http://blog.vodkamelone.de/archives/103-Zuruecksetzen-eines-Elmeg-VoIP-VPN-Gateway.html</link>
            <category>Bawue.Net</category>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/103-Zuruecksetzen-eines-Elmeg-VoIP-VPN-Gateway.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=103</wfw:comment>

    <slash:comments>7</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=103</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;img width=&quot;110&quot; height=&quot;63&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/elmeg/Elmeg-Modul-Gateway-2Sub-2M-300dpi-548px-cmyk.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;Für die &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.funkwerk-ec.com/index_de,,194.html&#039;);&quot;  href=&quot;http://www.funkwerk-ec.com/index_de,,194.html&quot; &gt;Elmeg&lt;/a&gt; &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.funkwerk-ec.com/prod_elmeg_ict_main_de,27594,194.html&#039;);&quot;  href=&quot;http://www.funkwerk-ec.com/prod_elmeg_ict_main_de,27594,194.html&quot; &gt;ICT-Serie&lt;/a&gt; von Telefonanlagen gibt es ein 
sogenanntes VoIP-VPN Gateway, dass der Telefonanlage &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/de.wikipedia.org/wiki/Session_Initiation_Protocol&#039;);&quot;  href=&quot;http://de.wikipedia.org/wiki/Session_Initiation_Protocol&quot;  title=&quot;Session Initiation Protocol&quot;&gt;SIP Fähigkeiten&lt;/a&gt; beibringt.&lt;/p&gt;

&lt;p&gt;Die interessanten Features des Moduls sind:
&lt;ul&gt;
 &lt;li&gt;Nutzung von maximal 10 SIP Providern als &quot;Amtsleitung&quot;&lt;/li&gt;
 &lt;li&gt;Anschluss von SIP-fähigen Telefonen als interne Nebenstelle&lt;/li&gt;
 &lt;li&gt;IPSec VPN Verbindungen
  &lt;ul&gt;
   &lt;li&gt;Voice-over-VPN möglich um externe Telefone als interne Nebenstelle zu nutzen&lt;/li&gt;
   &lt;li&gt;Zusammenschaltung von mehreren dieser Telefonanlagen über VPN Verbindungen um z.B. Niederlassungen günstig an das Hauptbüro anzuschliessen.&lt;/li&gt;
  &lt;/ul&gt;
 &lt;/li&gt;
 &lt;li&gt;Router Funktion
  &lt;ul&gt;
   &lt;li&gt;Mini Switch mit 3 internen Ports und einem WAN Anschluss.&lt;/li&gt;
   &lt;li&gt;Internetzugang über PPPoE, ISDN und PPtP, DHCP etc. möglich&lt;/li&gt;
   &lt;li&gt;Interner DHCP Server&lt;/li&gt;
   &lt;li&gt;Stateful Inspection Firewall oder Packet Filter&lt;/li&gt;
   &lt;li&gt;IP-Masquerading/NAT&lt;/li&gt;
   &lt;li&gt;RAS-Server und -Callback&lt;/li&gt;
   &lt;li&gt;Netzwerkweite LAN-CAPI Funktionalität&lt;/li&gt;
  &lt;/ul&gt;
 &lt;/li&gt;
&lt;/ul&gt;
&lt;/p&gt;

&lt;p&gt;Diese Features können realisiert werden, da das VoIP-VPN Gateway ein modifizierter Bintec Router ist.
&lt;p&gt;Das schöne daran ist, dass die Telefonanlage deswegen einen Telnet-Daemon laufen hat und man sich dort mit dem Login &quot;admin&quot; und dem Passwort &quot;fec&quot; einloggen kann und somit das Gerät wesentlich umfangreicher konfigurieren kann als über die vorgesehenen Windows Administrations Tools der Telefonanlage. z.B. für ordentliche IPSec Konfiguration ist das notwendig, oder wenn man Portforwardings aktivieren will.&lt;br /&gt;
Das unschöne ist, dass man die Konfiguration über Telnet so sehr vermurksen kann, dass das Gerät nicht mehr viel macht und sich direkt aufhängt.&lt;br /&gt;
Bei mir ging zwar noch der Login per telnet, aber sollte man dann versuchen &quot;setup&quot; oder einen anderen Befehl an der Shell einzugeben, so war erstmal Schluss.&lt;/p&gt;

&lt;p&gt;Der Funkwerk Support kennt in dem Fall die einfache Lösung, wie man das Problem beseitigen kann: Einschicken, wir reparieren das dann.&lt;/p&gt;

&lt;p&gt;Danke, aber das war die falsche Antwort.&lt;/p&gt;

&lt;p&gt;Aber es gibt ja genügend Stecker auf dem Board, einer wird schon helfen.&lt;/p&gt;
 &lt;br /&gt;&lt;a href=&quot;http://blog.vodkamelone.de/archives/103-Zuruecksetzen-eines-Elmeg-VoIP-VPN-Gateway.html#extended&quot;&gt;&quot;Zurücksetzen eines Elmeg VoIP-VPN Gateway&quot; vollständig lesen&lt;/a&gt;
    </content:encoded>

    <pubDate>Fri,  7 Jul 2006 15:41:00 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/103-guid.html</guid>
    
</item>
<item>
    <title>Spass mit der Rittal CMC-TC PUII</title>
    <link>http://blog.vodkamelone.de/archives/96-Spass-mit-der-Rittal-CMC-TC-PUII.html</link>
            <category>Bawue.Net</category>
            <category>CCC</category>
            <category>Fedora</category>
            <category>Hardware</category>
            <category>Unix</category>
    
    <comments>http://blog.vodkamelone.de/archives/96-Spass-mit-der-Rittal-CMC-TC-PUII.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=96</wfw:comment>

    <slash:comments>10</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=96</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;i&gt;[Note to english speaking readers, aggregating this blog: The following article is written in german about gaining root on a piece of embedded server monitor hardware from Rittal and configuring ssh access. If there is demand, I&#039;ll translate this article in english as well.]&lt;/i&gt;&lt;/p&gt;

&lt;p&gt;Ich hatte zuvor ja schon &lt;a href=&quot;http://blog.vodkamelone.de/archives/74-Sesam-oeffne-dich-per-SNMP.html&quot; &gt;hier&lt;/a&gt; und &lt;a href=&quot;http://blog.vodkamelone.de/archives/73-Ein-Heim-fuer-Server.html&quot; &gt;hier&lt;/a&gt; ein wenig über das Rittal CMC-TC System gesprochen, dass wir verwenden um unseren Serverschrank zu überwachen.&lt;/p&gt;

&lt;p&gt;Das System selber ist soweit ja sehr schön, und hat auch ein paar nette Features, aber leider fehlt z.B. der ssh Zugang. Telnet anzubieten ist doch schon ein wenig schwach heutzutage. Das ganze wäre ja kein Problem, würde Rittal sich an die GPL Lizenz halten, und mir den Sourcecode und die Buildumgebung zur Verfügung stellen, die gebraucht wird um sich einen eigenen sshd zu installieren.&lt;br /&gt;
Nunja, mal schauen was das noch wird.

&lt;p&gt;Nun will ich aber dennoch einen ssh Daemon auf dem Gerät haben, was sich auch nicht als sonderlich kompliziert rausstellt. Man muss das Gerät nur booten und den vorhandenen sshd starten.&lt;/p&gt;

&lt;p&gt;Aber fangen wir vorne an.&lt;/p&gt;

&lt;p&gt;Schauen wir uns also mal die Bootmeldungen an:
&lt;pre class=&quot;screen&quot;&gt;
U-Boot 1.1.3 (Jun  8 2005 - 15:08:40)

U-Boot code: 20F00000 -&gt; 20F1A868  BSS: -&gt; 20F1EE48
RAM Configuration:
Bank #0: 20000000 16 MB
Board: CMC-PU2 (Rittal GmbH)
Flash:  8 MB
In:    serial
Out:   serial
Err:   serial
Hit any key to stop autoboot:  0
no DHCP
## Booting image at 10030000 ...
   Image Name:   ARM Linux-2.4.27
   Created:      2005-04-22   4:52:03 UTC
   Image Type:   ARM Linux Kernel Image (gzip compressed)
   Data Size:    698499 Bytes = 682.1 kB
   Load Address: 20008000
   Entry Point:  20008000
   Verifying Checksum ... OK
   Uncompressing Kernel Image ... OK

Starting kernel ...

Linux version 2.4.27-vrs1 (mkr@s020403) (gcc version 2.95.4 20010319 (prerelease/franzo/20011204)) #2
     Fri Apr 22 06:49:12 CEST 2005
CPU: Arm920Tid(wb) revision 0
Machine: ATMEL AT91RM9200
On node 0 totalpages: 4096
zone(0): 4096 pages.
zone(1): 0 pages.
zone(2): 0 pages.
Kernel command line: root=/dev/mtdblock3 ro ethaddr=00:d0:93:12:34:56 ip=192.168.0.190::::
     CMC-TC-PU2::off console=ttyS0,9600
mtdparts=cmc_pu2:128k(uboot)ro,64k(environment),768k(linux),4096k(root),-
Calibrating delay loop... 89.70 BogoMIPS
Memory: 16MB = 16MB total
Memory: 14452KB available (1382K code, 275K data, 60K init)
Dentry cache hash table entries: 2048 (order: 2, 16384 bytes)
Inode cache hash table entries: 1024 (order: 1, 8192 bytes)
Mount cache hash table entries: 512 (order: 0, 4096 bytes)
Buffer cache hash table entries: 1024 (order: 0, 4096 bytes)
Page-cache hash table entries: 4096 (order: 2, 16384 bytes)
CPU: Testing write buffer: pass
POSIX conformance testing by UNIFIX
Linux NET4.0 for Linux 2.4
Based upon Swansea University Computer Society NET3.039
Initializing RT netlink socket
Starting kswapd
Installing knfsd (copyright (C) 1996 okir@monad.swb.de).
JFFS2 version 2.1. (C) 2001 Red Hat, Inc., designed by Axis Communications AB.
RAMDISK driver initialized: 16 RAM disks of 8192K size 1024 blocksize
 Amd/Fujitsu Extended Query Table v1.3 at 0x0040
number of CFI chips: 1
cfi_cmdset_0002: Disabling fast programming due to code brokenness.
Creating 5 MTD partitions on &quot;CMC PU2 flash&quot;:
0x00000000-0x00020000 : &quot;uboot&quot;
0x00020000-0x00030000 : &quot;environment&quot;
0x00030000-0x000f0000 : &quot;linux&quot;
0x000f0000-0x004f0000 : &quot;root&quot;
0x004f0000-0x00800000 : &quot;Partition_004&quot;
i2c-core.o: i2c core module version 2.6.1 (20010830)
i2c-dev.o: i2c /dev entries driver module version 2.6.1 (20010830)
ttyS0 at MMIO 0xfefc0000 (irq = 6) is a AT91_SERIAL
ttyS1 at MMIO 0xfefc4000 (irq = 7) is a AT91_SERIAL
ttyS2 at MMIO 0xfefc8000 (irq = 8) is a AT91_SERIAL
ttyS3 at MMIO 0xfefcc000 (irq = 9) is a AT91_SERIAL
ttyS4 at MMIO 0xfefff200 (irq = 1) is a AT91_SERIAL
eth0: Link now 100-FullDuplex
eth0: AT91 ethernet at 0xfefbc000 int=24 100-FullDuplex (00:d0:93:12:34:56)
eth0: Davicom 9196 PHY (Copper)
AT91 Watchdog Timer enabled (5 seconds)
Found AT91 i2c
I2C: RS5C372 RTC driver successfully loaded
CMC buzzer driver $Revision: 0.2 $
CMC digital IO driver $Revision: 0.2 $
Serial driver version 0.03 (2004-12-17) with no serial options enabled
ttyS5 at 0xc2084000 (irq = 29) is a TI16752
ttyS6 at 0xc2086000 (irq = 30) is a TI16752
NET4: Linux TCP/IP 1.0 for NET4.0
IP Protocols: ICMP, UDP, TCP
IP: routing cache hash table of 512 buckets, 4Kbytes
TCP: Hash tables configured (established 1024 bind 1024)
eth0: Link now 100-FullDuplex
IP-Config: Guessing netmask 255.255.255.0
IP-Config: Complete:
      device=eth0, addr=192.168.0.190, mask=255.255.255.0, gw=255.255.255.255,
     host=CMC-TC-PU2, domain=, nis-domain=(none),
     bootserver=255.255.255.255, rootserver=255.255.255.255, rootpath=
NET4: Unix domain sockets 1.0/SMP for Linux NET4.0.
NetWinder Floating Point Emulator V0.97 (double precision)
VFS: Mounted root (cramfs filesystem) readonly.
Freeing init memory: 60K
serial console detected.  Disabling virtual terminals.
init started:  BusyBox v0.60.2 (2002.10.10-17:17+0000) multi-call binary
eth0: ROVR error
eth0: ROVR error
Startup CMC
no update..
CMC Applications
rs422, Version: V2.00, Build Date: Mon Sep 19 18:01:58 2005
eeprom, Version: V2.00, Build Date: Mon Sep 19 18:00:03 2005

rs232, Version: V2.00, Build Date: Mon Sep 19 18:39:00 2005

CMC-TC-PU2 Thu Jan 1  1970 00:00:15, User 0
CMC-TC-PU2 login: VCC status = OK
cmc_main, Version: V2.15, Build Date: Wed Nov 16 15:20:38 2005
No Options..

Setting up clock 18:03:30 15.06.2006

CMC-TC-PU2 Thu Jun 15  2006 18:03:35, User 0
CMC-TC 192.168.0.190 login:
&lt;/pre&gt;

Eindeutig. Ein Linux mit einer BusyBox Shell. Eine im Embedded-Bereich sehr verbreitete Kombination. In diesem Fall leider ein Lizenzverstoss.&lt;/p&gt;

&lt;p&gt;Jetzt stellt sich die Frage, wie man root wird. Als Login hat man naemlich nur cmc und admin zur Verfügung, die beide normale Useraccounts sind und anstelle einer Shell ein fertiges Menü starten.&lt;/p&gt;
&lt;p&gt;Im Nachhinein, nachdem man sich auf dem Gerät umgeschaut hat, fallen mir verschiedene Möglichkeiten ein, aber die einfachste ist dem Bootloader zu sagen, dass ich gerne eine Shell hätte.&lt;br /&gt;
Mehr Details gibt es im Rest des Artikels.&lt;/p&gt; &lt;br /&gt;&lt;a href=&quot;http://blog.vodkamelone.de/archives/96-Spass-mit-der-Rittal-CMC-TC-PUII.html#extended&quot;&gt;&quot;Spass mit der Rittal CMC-TC PUII&quot; vollständig lesen&lt;/a&gt;
    </content:encoded>

    <pubDate>Thu, 29 Jun 2006 14:15:00 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/96-guid.html</guid>
    
</item>
<item>
    <title>Bosse T315 auf Tonwahl umstellen</title>
    <link>http://blog.vodkamelone.de/archives/84-Bosse-T315-auf-Tonwahl-umstellen.html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/84-Bosse-T315-auf-Tonwahl-umstellen.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=84</wfw:comment>

    <slash:comments>1</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=84</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;img width=&quot;110&quot; height=&quot;73&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/bosse-telefon.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;Mara hatte das Telefon links gekauft, um es an einen VoIP Adapter anzuschliessen.&lt;br /&gt;
Das Funktionierte soweit auch gut, aber das Telefon war leider auf Pulswahl eingestellt, und da kein Handbuch dabei war, musste ich mal ein wenig suchen.&lt;/p&gt;
&lt;p&gt;Das tolle am Internet ist ja, dass es für wirklich alles eine FAQ gibt. So auch hierfür. Auf &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.mhessler.de/mfvfaq/mfvfaq2.html&#039;);&quot;  href=&quot;http://www.mhessler.de/mfvfaq/mfvfaq2.html&quot;&gt;FAQ für MFV Telefone&lt;/a&gt; wurde ich dann fündig.&lt;/p&gt;
&lt;p&gt;Die Vorgehensweise um ein Bosse T315 von Pulswahl auf Tonwahl umzustellen ist also: &quot;SET 1 1590 Wahlwiederholung 037 SET&quot;.&lt;br /&gt;
Also die Set Taste drücken (Pfeil der in das auf der Ecke stehende Quadrat zeigt), dann 1, dann 1590 und die Wahlwiederholungstaste. Dann 037 für MFV+Flash, oder 036 für MFV+Erde oder 033 für IWV+Erde und dann nochmal die Set Taste.&lt;br /&gt;
Fertig.&lt;/p&gt; 
    </content:encoded>

    <pubDate>Mon,  6 Feb 2006 17:11:22 +0100</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/84-guid.html</guid>
    
</item>
<item>
    <title>Siemens S65 Telefoncode zurücksetzen</title>
    <link>http://blog.vodkamelone.de/archives/80-Siemens-S65-Telefoncode-zuruecksetzen.html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/80-Siemens-S65-Telefoncode-zuruecksetzen.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=80</wfw:comment>

    <slash:comments>185</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=80</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;img width=&quot;66&quot; height=&quot;110&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/s65/siemens-S65.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;Einige haben es ja bereits mitbekommen, als ich darüber geflucht habe, aber mein Siemens (nein, Siemens, nicht BenQ) S65 Mobiltelefon ist vom unehrlichen Finder nicht zurückgegeben worden, sprich geklaut worden.&lt;/p&gt;

&lt;p&gt;Von einem Freund habe ich ein gebrauchtes Siemens S65 kaufen können, dass dieser bei EBay bekommen hat.&lt;br /&gt;
Soweit so gut, das dumme ist nur, dieses Telefon hat einen sogenannten Telefoncode gesetzt gehabt, also eine PIN für das Telefon. Im normalen Betrieb stört das nicht weiter da die PIN nirgends gebraucht wird.&lt;/p&gt;
&lt;p&gt;&lt;img width=&quot;132&quot; height=&quot;176&quot; style=&quot;float: right; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/s65/telefon-code.gif&quot; alt=&quot;&quot;  /&gt;Sobald man aber versucht die MMC Karte zu formatieren oder das komplette Adressbuch zu löschen wird nach dieser PIN gefragt. (Siehe rechts, hier in der Version &quot;Vodafone Branding&quot;)&lt;br /&gt;
Nur kenne ich die nicht. :-(&lt;/p&gt;

&lt;p&gt;Siemens verlangt 29,95&amp;euro; Servicepauschale um diese PIN wieder zu entfernen.&lt;br /&gt;
Bei den üblichen Stundenpreisen der Behörde mit angeschlossenem Elektronikkonzern ist das sicher ein günstiger Stundensatz, aber ich finde das immer noch unnötig.&lt;br /&gt;
Ist aber auch nicht schlimm, es gibt eine Möglichkeit den sogenannten Mastercode selber zu berechnen, mit dem der Telefoncode wieder gelöscht werden kann.&lt;/p&gt; &lt;br /&gt;&lt;a href=&quot;http://blog.vodkamelone.de/archives/80-Siemens-S65-Telefoncode-zuruecksetzen.html#extended&quot;&gt;&quot;Siemens S65 Telefoncode zurücksetzen&quot; vollständig lesen&lt;/a&gt;
    </content:encoded>

    <pubDate>Tue, 22 Nov 2005 21:10:00 +0100</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/80-guid.html</guid>
    
</item>
<item>
    <title>Openvpn und VPNC auf dem Nokia 770</title>
    <link>http://blog.vodkamelone.de/archives/76-Openvpn-und-VPNC-auf-dem-Nokia-770.html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/76-Openvpn-und-VPNC-auf-dem-Nokia-770.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=76</wfw:comment>

    <slash:comments>2</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=76</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;Aus dem dmesg log:&lt;/p&gt;

&lt;pre&gt;tun: Universal TUN/TAP device driver, 1.6
tun: (C) 1999-2004 Max Krasnyansky &lt;maxk@qualcomm.com&gt;&lt;/pre&gt;

&lt;p&gt;Das ist doch mal ein gutes Zeichen. Damit sollten sowohl OpenVPN als auch VPNC auf dem Nokia lauffähig sein. Mal ein wenig crosskompilieren gehen und schauen ob ich noch ein kleines Frontend hinbekomme zum hoch und runterfahren des Tunnels.&lt;/p&gt; 
    </content:encoded>

    <pubDate>Sat, 22 Oct 2005 21:55:33 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/76-guid.html</guid>
    
</item>
<item>
    <title>Das Nokia 770 ist da</title>
    <link>http://blog.vodkamelone.de/archives/75-Das-Nokia-770-ist-da.html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/75-Das-Nokia-770-ist-da.html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=75</wfw:comment>

    <slash:comments>2</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=75</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;a href=&#039;http://blog.vodkamelone.de/uploads/nokia770/nokia770_schachtel.jpg&#039;&gt;&lt;img width=&quot;110&quot; height=&quot;83&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/nokia770/nokia770_schachtel.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;&lt;/a&gt;Haha, als ich gestern nach Hause kam, wartete da schon das Paket mit dem Nokia 770 auf mich.&lt;br /&gt;
Direkt aus Finland, vom Nokia Hauptquartier und netterweise mit &quot;Electronic equipment without commercial value&quot; beschriftet. Stimmt ja auch. Ist a) ein Geschenk und b) eine Entwickler-Pre-Release.&lt;br /&gt;
Aus dem Grund lag auch ein &quot;Warranty-Waiver&quot; dabei. Das besagt, dass Nokia mir das Gerät für umsonst gibt, ich dafür aber keine Garantie erhalte, und bei Schäden etc. die Reparatur selber bezahlen muss. Ansonsten besteht evtl. die Möglichkeit, einen Support Vertrag in Anspruch zu nehmen, aber Nokia garantiert nicht, dass ich die Möglichkeit dazu habe...&lt;br /&gt;
Naja, es war umsonst, da habe ich Verständnis dafür.&lt;/p&gt;
 &lt;br /&gt;&lt;a href=&quot;http://blog.vodkamelone.de/archives/75-Das-Nokia-770-ist-da.html#extended&quot;&gt;&quot;Das Nokia 770 ist da&quot; vollständig lesen&lt;/a&gt;
    </content:encoded>

    <pubDate>Sat, 22 Oct 2005 18:15:00 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/75-guid.html</guid>
    
</item>
<item>
    <title>Yessss! My own Nokia 770.</title>
    <link>http://blog.vodkamelone.de/archives/48-Yessss!-My-own-Nokia-770..html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/48-Yessss!-My-own-Nokia-770..html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=48</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=48</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;a href=&#039;http://blog.vodkamelone.de/uploads/770.jpg&#039;&gt;&lt;img width=&quot;110&quot; height=&quot;75&quot; style=&quot;float: left; border: 0px; padding-left: 5px; padding-right: 5px;&quot; src=&quot;http://blog.vodkamelone.de/uploads/770.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;&lt;/a&gt;Cool. I&#039;m sitting here at the Nokia presentation about their new &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.nokia.com/nokia/0,1522,,00.html?orig=/770&#039;);&quot;  href=&quot;http://www.nokia.com/nokia/0,1522,,00.html?orig=/770&quot;&gt;Nokia Internet Tablet 770&lt;/a&gt; at &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.guadec.org&#039;);&quot;  href=&quot;http://www.guadec.org&quot;&gt;Guadec&lt;/a&gt;. This seems like a nice gadget, it&#039;s a small tablet embedded computer, running only &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/maemo.org/&#039;);&quot;  href=&quot;http://maemo.org/&quot;&gt;open source software&lt;/a&gt; (debian and gnome) and no closed binaries. This thingy allows the user to access the internet and do stuff on the run... Pretty neat.&lt;/p&gt;
&lt;p&gt;Cool stuff. And best of all, Nokia was giving 30 away in a raffle at the event. And I got one. YEAH! ;-)&lt;/p&gt;
&lt;p&gt;&lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.gizmodo.com/gadgets/pdas/hands-on-with-the-nokia-770-pda-105100.php&#039;);&quot;  href=&quot;http://www.gizmodo.com/gadgets/pdas/hands-on-with-the-nokia-770-pda-105100.php&quot;&gt;Gizmode reported about some hands-on experience&lt;/a&gt;, well I&#039;ll offer my own opinion about the 770 as soon as I have one.&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Update:&lt;/b&gt; A funny fact on the side: When Ari Jaaksi from Nokia announced that the system is running only open source software, while people would expect Nokia to put a proprietary software stack on top of linux, he earned some well deserved standing ovations.&lt;/p&gt; 
    </content:encoded>

    <pubDate>Sat, 28 May 2005 21:26:35 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/48-guid.html</guid>
    
</item>
<item>
    <title>Another one bites the dust...</title>
    <link>http://blog.vodkamelone.de/archives/12-Another-one-bites-the-dust....html</link>
            <category>Hardware</category>
    
    <comments>http://blog.vodkamelone.de/archives/12-Another-one-bites-the-dust....html#comments</comments>
    <wfw:comment>http://blog.vodkamelone.de/wfwcomment.php?cid=12</wfw:comment>

    <slash:comments>2</slash:comments>
    <wfw:commentRss>http://blog.vodkamelone.de/rss.php?version=2.0&amp;type=comments&amp;cid=12</wfw:commentRss>
    

    <author>andreas@dicp.de (andreas)</author>
    <content:encoded>
    &lt;p&gt;&lt;a href=&#039;http://blog.vodkamelone.de/uploads/drive-cable-lg.jpg&#039;&gt;&lt;img border=&quot;0&quot; hspace=&quot;5&quot; align=&quot;left&quot; src=&quot;http://blog.vodkamelone.de/uploads/drive-cable-lg.serendipityThumb.jpg&quot; alt=&quot;&quot;  /&gt;&lt;/a&gt;Ich mache eine weitere Kerbe in den Schreibtisch.&lt;br /&gt;
Zwei weitere Festplatten sind heute gestorben. Beide kamen aus dem Hause &lt;a href=&quot;http://blog.vodkamelone.de/exit.php?url=aHR0cDovL3d3dy5tYXh0b3IuY29tL3BvcnRhbC9zaXRlL01heHRvci8/ZXBpX21lbnVJdGVtSUQ9ZmY0YWJhOWI1YTE1NDMyNzE0MDA1ODU3NjBiNDYwNjgmZXBpX21lbnVJRD05NzZkMzdjZDQ3OGM1ODI2NDMzZjIyNjA3NWI0NjA2OCZlcGlfYmFzZU1lbnVJRD05NzZkMzdjZDQ3OGM1ODI2NDMzZjIyNjA3NWI0NjA2OCZjaGFubmVscGF0aD0vZW5fdXMvU3VwcG9ydC9XYXJyYW50eSUyMFNlcnZpY2Vz&amp;amp;entry_id=7&quot;&gt;Maxtor &lt;/a&gt;und waren noch nichtmal einen Monat in Benutzung. Die eine Platte war das Austauschmodell von Maxtor dass mir erst letzten Monat kaputtgegangen ist.&lt;/p&gt;

&lt;p&gt;Falls jemand was damit anfangen kann, die lustigen Fehlermeldungen die die Platten werfen, wenn sie mit &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.maxtor.com/portal/site/Maxtor/?epi_menuItemID=3c67e325e0a6b1f6294198b091346068&amp;amp;amp;epi_menuID=976d37cd478c5826433f226075b46068&amp;amp;amp;epi_baseMenuID=976d37cd478c5826433f226075b46068&amp;amp;amp;channelpath=/en_us/Support/Software%20Downloads/ATA%20Hard%20Drives&amp;amp;amp;downloadID=22&amp;amp;amp;displayEULA=true&#039;);&quot;  href=&quot;http://www.maxtor.com/portal/site/Maxtor/?epi_menuItemID=3c67e325e0a6b1f6294198b091346068&amp;amp;epi_menuID=976d37cd478c5826433f226075b46068&amp;amp;epi_baseMenuID=976d37cd478c5826433f226075b46068&amp;amp;channelpath=/en_us/Support/Software%20Downloads/ATA%20Hard%20Drives&amp;amp;downloadID=22&amp;amp;displayEULA=true&quot;&gt;Powermax&lt;/a&gt; getestet werden, sind de9fc87d und de9e9675. Mich würde ja mal wirklich interessieren was diese aussagen.&lt;/p&gt;

&lt;p&gt;Ich glaube, ich sollte bald wirklich eine Statistik anfangen welche Platten wie oft kaputtgehen.&lt;br /&gt;
Der aktuelle Counter ist bei 10 toten Platten seit dem 1. August 2004.&lt;/p&gt; 
    </content:encoded>

    <pubDate>Sat,  2 Oct 2004 17:36:27 +0200</pubDate>
    <guid isPermaLink="false">http://blog.vodkamelone.de/archives/12-guid.html</guid>
    
</item>

</channel>
</rss>