1. Openmoko developers program

    Yesterday during iPhone discussion I gave URL to OpenMoko phone to some people on IRC. After that I had to answer many questions about it. One of them was Webdesigner and put some critic on colorscheme used on screenshot:

    Colorscheme is one of those awful ones. Why grey with orange???

    Then I visited OM website and discovered that they started developer program finally. Now I wonder — do I have to write to Mickeyl regarding embedded Linux projects I had contributed to or not…

    UPDATE: Koen told me that this info was there from start. So I had to miss it…

    Written by Marcin Juszkiewicz on
  2. Zaurus line officially ended

    Yesterday I got official information that Sharp ended Zaurus line — last production will be in February 2007 and then nothing — no new models, no building of older models. Many people wrote that this is bad thing, that they will miss new toys with Zaurus name…

    I am not one of them. Since SL-C3000 (called “spitz”) model I had a feeling that Sharp is not able to create new handheld device for mass market. There was few new things in it but basically it was old clamshell line on steroids. Palmtop built to be used as English<>Japanese dictionary rather then as PDA. Then they released SL-C1000 (“akita)” which was spitz without hard drive (in form of 4GB CompactFlash microdrive) but with 128MB of Flash memory like it was in end of previous clamshell line. Both models were selling quite good and one day Sharp merged Akita and 4GB microdrive and thats how SL-C3100 (“borzoi”) was created. Again nothing new… Some months ago they got out of stock of 4GB cards so SL-C3200 (“terrier”) was created — with 6GB microdrive.

    But those models were much worse then other palmtops on market… Windows Mobile devices got Bluetooth as standard, more and more models got WiFi inside (now even 802.11g instead of old 802.11b standard). Sharp did not even tried to compete with them. There were rumours that there was a plan to release SL-C3500 which would get WiFi inside but knowing Sharp it would be some shitty wlan-ng USB stick with drivers lacking WPA and any good support.

    Add to it their lack of any support to users… Can you imagine that 2006 models were sold with few years old software created for first Zaurus models? They only did some small modifications to get some of new features supported. Someone told one day:

    Sharp should concentrate on building Zaurus models. But they should not touch software — OpenZaurus or pdaX teams do it in much better way.

    So I think that it is good that they finally ended Zaurus line — it was visible that they do not have idea which way to go and how to support users of own toys.

    BTW: some people asked what will OpenZaurus team do now — we are working on 3.5.5 release for all existing models (except SL-A300 as usual). After release most of us will probably concentrate on fixing bugs, adding software and will move to Ångström distribution as this is future of embedded distros.

    Written by Marcin Juszkiewicz on
  3. Backlight control working on Progear

    Yesterday I finally found some time to test Ångström on progear. Kernel needed to be recompiled (I forgot to include ATA driver) and finally it boot.

    Console in VGA mode on XGA screen does not looks good but I ignored it (this is something to fix later). WiFi works, USB keyboard works so I was ready to tweak.

    I baked some recipes to get some extra modules and got AC, Battery and Backlight support. It was not ideal but working. I think that next step will be rewriting those drivers and including them in mainline kernel.

    First step is done — I converted progear-lcd module into progear_bl which use backlight subsystem and send it to LKML. Got some comments, updated code and who knows — maybe 2.6.21 will get it included…

    BTW — It is my first real code submitted into kernel.

    Written by Marcin Juszkiewicz on
  4. 2006 timeline

    2006 year was good. I did few releases as OpenZaurus maintainer, created own company for my paid OpenEmbedded work, got some job offers from respected companies.

    January

    February

    March

    April

    May

    June

    July

    August

    September

    October

    November

    December

    Written by Marcin Juszkiewicz on
  5. Self hosted Ångström build

    During weekend I was working on getting self hosted build of OpenEmbedded.

    I built Ångström-2007.1 for progear and chrooted into resulting image. Then installed some packages, copied OE metadata, archives for SRC_URI and did bitbake nano build.

    Some packages was needed to be installed — I added them into new task named task-self-hosting which should contain everything needed to get self hosted build running.

    But there were some problems:

    1. rpcgen from glibc-utils require cpp

    This can be solved by adding RDEPENDS_glibc-utils = "cpp" into glibc.bb recipe. But this is theory because we need glibc to build gcc so dependency chain is result.

    1. glibc-dev ‘conflict’ libc-linux-headers-dev

    Few headers exists in both packages — I do not know which one are more important. In my build I forced glibc-dev ones.

    1. binutils-symlinks ‘conflict’ busybox (and elfutils)

    This is reported already in OpenEmbedded bugtracker.

    1. subversion has problems with building — I need to check do I have some not-yet-committed patches for apr(-util) and subversion.

    2. Perl is too granulated — I installed all 861 perl packages to get quilt-native happy instead of checking which are needed.

    But the best thing is that whole process can be done. This shows that OpenEmbedded based distributions are able to build them self using software from feeds.

    Written by Marcin Juszkiewicz on
  6. Flashing Progear BIOS

    Today I checked how to flash BIOS on Progear HX1050 webpad. Basically there are two ways:

    • using psplash.exe under DOS
    • using fpFlashBIOS under GNU/Linux

    I do not know does they were provided with default installations.

    Flashing under GNU/Linux (Debian ‘testing’ in my case) is simple:

    sync
    ./fpFlashBIOS -w:pb_10404.rom
    

    Application will write some flash block (and verify). Then reboot to check does everything is OK — due to fact, that flashing clear BIOS settings external USB keyboard is recommended. Pressing F2 during bootup (when white screen is shown) will enter Setup.

    Beware: unbricking can be hard — flash chips are soldered…

    Written by Marcin Juszkiewicz on
  7. Job change

    Yesterday I got job offer from one company. They want me to work for them in full time during next months. The best thing is that this job is OpenEmbedded related so I will do what I like to do and will be paid for it.

    I accepted offer (who will not :) and today discussed with my current boss about leaving. So from February 2007 I will be free man — only own company work. In other words — starting from Feb 2007 I will get busy on OE rather then on making websites (my current job).

    Written by Marcin Juszkiewicz on
  8. How to use task-base

    In OpenEmbedded we had long discussions how to get minimal images few times, there were developers which worked on getting smallest possible working ones — one of them was Matthias Hentges which essential-to-boot image was 3.5M jffs2 and had everything needed to use WiFi on Sharp Zaurus SL-C1000 (akita).

    Finally Richard Purdie added task-base into OpenEmbedded repository as new idea to generate rootfs images. First version was far from perfect but show a way. We improved it a lot since then so now it support:

    • Linux 2.4/2.6
    • power management systems: APM, ACPI
    • wireless connectivity: Bluetooth, Wifi, Irda
    • USB host and gadget (gadget only under 2.6 because 2.4 lack any)
    • keyboards
    • touchscreens
    • screen in machines which have them
    • PCI, PCMCIA/CF bus
    • internal storage for models with microdrives or hard disks (‘ext2’ feature)
    • NFS for nfsroot installations
    • IPSec

    Any new features are easy to add.

    Why switch from task-bootstrap to task-base is required now for all target devices and distributions? Reason is simple — this allow much better integration of them and leverage possibility of forgetting something. For example in past one of our distributions supported WPA ‘out of box’ but there were problems with some methods of encryption — it was fixed by update with few extra kernel modules added. Now imagine that you have to change this thing for all distributions and have to check which of them support wireless with WPA capable drivers — nightmare… Instead of it you change task-base recipe and every distro will get this update for free.

    Another bonus which distro/machine maintainers get with task-base is simplify of configurations. There is no need to specify all tools again and again, thinking which parts of rootfs should be specified in machine config and which in distribution one. Instead of it only features of target and distro has to be defined and task-base will handle rest of it.

    Example

    Few months ago I was working on creating new distribution called celinux-test for CELF. Main target of it was omap5912osk developer board. I decided to use task-base from beginning.

    Cleaning machine and distro config

    omap5912osk.conf was long because this board has modular kernel so lot of modules need to be present in rootfs. I started from definition of MACHINE_FEATURES and switch to task-base:

    MACHINE_FEATURES = "kernel26 pcmcia usbhost"
    MACHINE_TASK_PROVIDER = "task-base"
    

    Then I build bootstrap-image and compared amount of packages installed with a list from older rootfs. Some tools were lacking so I checked them and added proper features to celinux-test distribution config:

    DISTRO_FEATURES = "nfs pcmcia usbhost"
    

    Rebuild of task-base and bootstrap-image gave me rootfs which contained nearly same set of packages as old image. New one got some additional pcmcia modules, usbutils but every needed utils present in older images were present.

    Extra stuff

    Cleaning of configs allow to remove all BOOTSTRAP_* variables. But how to add some packages into rootfs without them? There is solution — MACHINE_EXTRA_RDEPENDS/MACHINE_EXTRA_RRECOMMENDS and same for distros: DISTRO_EXTRA_RDEPENDS/DISTRO_EXTRA_RRECOMMENDS. Everything from them will get added into task-base dependencies.

    Written by Marcin Juszkiewicz on
Page 89 / 106