Languages: |
English • العربية • Български • Česky • Dansk • Deutsch • Esperanto • Eesti • Español • فارسی • Suomi • Français • עברית • Magyar • Italiano • 한국어 • Nederlands • Norsk (bokmål) • Polski • Português • Română • Русский • Svenska • Slovenčina • Українська • 中文(中国大陆) • 中文(台灣) • Euskara • Català |
There are "official" instructions on how to install Debian on FreeRunner or Debian on Neo1973 (see the original announcement).
Previous information (partly outdated, now) on how to install Debian manually has been moved to Manual Debian.
See also : http://www.debian.org/ to know more about Debian.
From time to time the Debian packages may be broken, which will cause the install.sh script to fail. Since waiting for the packages to be fixed can take quite a lot of patience, here is an alternative method of getting Debian installed on the FreeRunner.
Please discuss debian related issues on the smartphones-standards@linuxtogo.org mailing list and Cc: pkg-fso-maint@lists.alioth.debian.org in your bug reports.
The default root password is blank. You should change that as soon as you can:
# passwd
If entering a blank password does not work at first, try rebooting. If still no success, boot to 2008.08/2007.02, chroot to the micro SD card and set a new password.
Note: By default, Debian is already configured to write limited messages to the console during boot. Does this actually speed things up anymore?
What's good for every linux booting is also good for our debian on the freerunner: booting in quiet mode. To do so by default just boot your Neo FreeRunner in NOR-Flash and execute this configure-script: configure-uboot.sh.
It changes default booting to quiet-mode and adds another boot-option to boot without quiet-mode for debugging purpose.
Press the power button or run 'apm -s' to suspend.
The default time zone is UTC. Reconfigure it by running
# dpkg-reconfigure tzdata
To set the clock manually do something like
# date -s 00:33
If you have a network connection, do something like
# apt-get install ntpdate # ntpdate-debian
Issues:
If you don't want to mess up with configuration files and is looking for an easy gui for wireless configuration, then wifi-radar or wicd is what you are looking for.
apt-get install wifi-radar wifi-radar
or
apt-get install wicd wicd-client -n
If you are looking for more, read on...
Make sure the following packages are installed:
apt-get install wireless-tools wpasupplicant dhcp3-client
Assuming your wireless router uses WPA security and DHCP,
edit /etc/network/interfaces
to include a section like this:
auto eth0 iface eth0 inet dhcp wpa-driver wext wpa-ssid "MyWirelessName" wpa-psk "MyWirelessPassword"
Where, of course, you're using the name of your wireless network and it's password instead of MyWirelessName and MyWirelessPassword.
You can test by running
# ifup eth0
You can determine your IP address by running
# ifconfig eth0
Issues:
ifup eth0
Once wpa_supplicant has begun managing your wifi interface, you should type "wpa_action eth0 stop" instead of "ifdown eth0".
Todo: Which of the issues that single network configurations suffer from are addressed by WPA roaming mode? Would ifplugd / guessnet help, or just make things more complicated?
To configure WPA to roam between wireless networks, you will need to create a new configuration file:
/etc/wpa_supplicant/wpa_supplicant.conf
a template for this file (and more documentation) is available in:
/usr/share/doc/wpasupplicant/examples/wpa-roam.conf
You'll need to add networks to this file. Examples:
network={ ssid="MySSID" key_mgmt=NONE wep_key0="abcdefghijklm" # wep_key0=6162636465 # <- no quotes, so hex number wep_tx_keyidx=0 id_str="MySSID" }
network={ ssid="SomeNetwork" key_mgmt=NONE }
network={ ssid="Example WPA Network" psk="mysecretpassphrase" id_str="home" }
Next, you'll need to edit /etc/network/interfaces. This lets you configure your wireless networks to use dhcp, or other appropriate TCP/IP settings:
auto eth0 iface eth0 inet manual wpa-driver wext wpa-roam /etc/wpa_supplicant/wpa_supplicant.conf # MySSID comes from an id_str above. iface MySSID inet dhcp # default is what's used if there is no id_str setting. # so the 'SomeNetwork' network will use DHCP. iface default inet dhcp iface home inet static # static interface settings, or whatever...
Finally, if you want attempts to access the internet to default to eth0 (and not usb0), then comment out this line under usb0 adapter configuration:
gateway 192.168.0.200
For some reason, I had to reboot for the id_str settings to take effect. However, you should now be able to use "ifup eth0" to associate with the access point and "wpa_action eth0 stop" to down the wifi adapter.
To use all the possibilities of wpasupplicant
like roaming and automatic connection to different networks,
you should read /usr/share/doc/wpasupplicant/README.Debian.gz
The FreeRunner uses the standard Linux bluez stack, installed with
# apt-get install bluez-utils
There is also a module missing from /etc/modules, which is critical to getting your device recognized. (kudos to johnsu01 on irc.freenode.net:#openmoko-debian for the find)
# echo ohci-hcd >> /etc/modules
The first time you try this, you can also
# modprobe ohci-hcd
The only atypical part of using bluetooth on the FreeRunner is turning it on, which can be done with
# echo 1 > /sys/bus/platform/devices/neo1973-pm-bt.0/power_on # echo 0 > /sys/bus/platform/devices/neo1973-pm-bt.0/reset
Then the device should be visible using
# hcitool dev
TODO: Then what to do next? (See: To-Do List) |
By default debian uses fbdev, but we can use Xglamo to get better performance:
apt-get install xserver-xglamo
after that edit /etc/X11/xorg.conf and change the line
Driver "fbdev"
to:
Driver "Xglamo"
and if you want to run xserver as normal user:
chmod u+s /usr/bin/Xglamo
with that you:
Using xglamo you must remember that:
1. Create a new user
# useradd -m -G audio,dialout,floppy,video,staff username # passwd username
2. Edit /etc/init.d/nodm and change USER=root to USER=username in it. Then to make sure changes are not lost on upgrade, run
dpkg-divert --add /etc/init.d/nodm
This will make new versions of /etc/init.d/nodm be written to /etc/init.d/nodm.distrib
3. Edit /etc/X11/Xwrapper.config
and change allowed_users=console
to allowed_users=anybody
4. Copy /root/.xsession into ~username/
5. Note that, if you ran zhone as root first, you may have to change ownership or remove /tmp/zhone.log, as a normal user is not able to write to a file owned by root.
Make sure to put your user in the audio group ("adduser <username> audio").
If there is no error but no sound, try these state files: Talk:Manual_Debian#Sound
When Debian is installed, the kernel is provided by the package linux-image-2.6.24-openmoko-gta02
. This package can be installed only in POSIX compliant filesystems, so it can not be used if your boot partition is a vfat one. Your kernel will be keep updated like the other packages of the system. You must to use this way if you are unsure and you need an (almost) stable system.
Otherwise you can choose to manual install an OM kernel. But only do this if you know what you are doing. At the moment there is a little problem in the question which kernel to use. Hopefully it will be solved in the near future.
The original openmoko kernel works fine inclusive suspending and supports different really nice usb gadgets (not all working at the moment). :)
download stable: http://downloads.openmoko.org/releases/Om2008.9/
download testing: http://downloads.openmoko.org/daily/
The new FSO4 kernel works fine and suspend/resume is also possible. But this kernel still has no loadable usb gadget modules (10-Nov-2008). :/
download testing: http://downloads.freesmartphone.org/fso-testing/images/
download unstable: http://downloads.freesmartphone.org/fso-unstable/images/
mv /boot/uImage.bin /boot/uImage.bin.old
, then mv /lib/modules/2.6.24 /lib/modules/2.6.24.old
, then chown -R root.root /lib/modules/2.6.24
because the owner from the tar.gz is something else (for me).
depmod -a
.
echo g_ether >> /etc/modules
. I read in an email, that the module "ohci-hcd" is also needed for some bluetooth functions, but i don't know this for real. I inserted it to my modules file to be on the safe side.
You can install dselect(~2.2MB) or aptitude(~12MB) to visually inspect the available debian packages using the desktop's console.
Also the gtk-based package-manager synaptic(~15.7MB) is working
after installing lsb-release and hicolor-icon-theme, but it is very slow.
Finally, on constrained systems, just issue the command:
grep -e Package: -e Description /var/lib/dpkg/available|more
Arne Anka suggested trying the light-weight webkit-based midori browser:
apt-get install midori
Another light-weight browser is Dillo. It can be easily installed with:
apt-get install dillo
If you think the previous options are quite slow on Freerunner try Links2.
apt-get install links2
Run as:
xlinks2
Openmoko Freerunner has integrated a good AGPS chip that can be used to know in every moment the phone position. The most known free applications to use gps with graphical maps are:
(Attention: Navit is not yet present on Debian repository)
Evince is also available in debian, and handles pdf, djvu, cbz, and other formats.
There is also a hack to convert drm protected adobe ebooks to .cbz files readable with evince, which is mentioned on the mailing list.
fbpanel is a fast, lightweight, gtk2 desktop panel.
sudo apt-get install fbpanel
~/.xsession
#!/bin/sh export GTK_MODULES=libgtkstylus.so zhone & xsetroot -solid black matchbox-keyboard-toggle & matchbox-window-manager -use_titlebar yes & # -use_titlebar yes to minimize & toggle between apps # fbpanel's taskbar does not work with matchbox-window-manager #~/bin/auxlaunch & while true; do fbpanel; sleep 1; done;
~/.fbpanel/default
mkdir ~/.fbpanel cp /etc/fbpanel/default ~/.fbpanel/default nano ~/.fbpanel/default
Remove section with 'taskbar' plugin - it's useless with matchbox-window-manager. You may add plugin 'cpu'
Plugin { type = cpu }
Also, plugin 'genmon' is useful:
Plugin { type = genmon config { Command = echo -e $(grep "MemFree" /proc/meminfo | awk '{printf "%0.2f", $2 / 1024}') "|"\ $(cat /proc/loadavg | awk '{print $3}') "|" $(apm | awk '{print $5}') PollingTime = 60 TextSize = small TextColor = darkblue } }After 'killall fbpanel' it will show: free mem in megabytes | loadavg | battery % left.
~/.gtkrc-2.0
sudo apt-cache search gtk2-engines sudo apt-get install gtk2-engines gtk-theme-switch DISPLAY=:0 gtk-theme-switch2Now choose your theme, font and save it. To see changes do 'killall fbpanel'.
The debian installation script installs by default the matchbox window manager. It doesn't feature a desktop environment. xfce is a small and lightweight desktop environment and so is quite fast for the FreeRunner.
apt-get install xfce4
Edit your .xsession to launch xfce4 at X startup :
#!/bin/sh xfce4-session
Edit section [Failsafe Session] of /etc/xdg/xfce4-session/xfce4-session.rc (or ~/.config/xfce4-session/xfce4-session.rc) to handle the auto-started apps. For example:
[Failsafe Session] Count=3 Client0_Command=xfce4-panel Client0_PerScreen=False Client1_Command=xfdesktop Client1_PerScreen=False Client2_Command=zhone Client2_PerScreen=True
Start XFCE !
/etc/init.d/nodm restart
The desktop takes a while to start but once up was snappy as can be expected. I've not yet looked at the reason for the seemingly too slow start for the desktop.
zhone is available from the "Office" menu in xfce. The matchbox keyboard is available in "Accessories".
If you want to display the screen on the long side (ie rotated, 4:3 aspect), add the following to the /etc/X11/xorg.conf in both the Device and InputDevice sections :
Option "Rotate" "CCW"
and then (re)start xfce.
If you want to be able to shutdown/restart the device, add the following line to /etc/sudoers (don't forget to replace username with your actual username):
username localhost = NOPASSWD: /usr/sbin/xfsm-shutdown-helper
XFCE's window manager is poorly configured for use with the FreeRunner. Fortunately, matchbox's window manager is compatible with xfce. To use the matchbox window manager, modify ~/.xsession as follows:
#!/bin/sh exec matchbox-window-manager -use_titlebar no -use_cursor no & xfce4-session
I you want a really nice desktop enviroment but you think XFCE is too fat, you can try to install LXDE. It give to you the GTK comfort, but use only a fraction of the ram needed by XFCE.
To install it:
apt-get install lxde
to launch it create a /etc/init.d/lxde
script in the same way descripted for xfce4, replacing startxfce4
accorence with startlxde
.
Matchbox has an option, use_cursor
, that can be used to control whether to show the cursor.
For the default setup, edit /usr/bin/zhone-session
and change the matchbox command to
matchbox-window-manager -use_titlebar no -use_cursor no
Unclutter is a program that hides the cursor after a period of inactivity. To use unclutter, install it
and choose Yes to the question Start unclutter automatically?
. To change settings edit
/etc/default/unclutter
.
To make the cursor invisible create a file called empty.cursor with this content:
#define empty.cursor_width 16 #define empty.cursor_height 16 static unsigned char empty.cursor_bits[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
Now you can execute: xsetroot -cursor empty.cursor empty.cursor and the cursor will be invisible. To make this permanent you have to invent something ;) It must be executed after zhone has finished starting up.
Sometimes it is helpful to have a big screen, keyboard and mouse. You can run X applications in a nested X server window. On your desktop install the nested X server application Xephyr (better that Xnest) apt-get install xserver-xephyr Run a nested X server as display :1 Xephyr :1 -ac -br -screen 480x640 -reset -terminate & Now you are able to run apps on your Neo which will display on your desktop PC. Make sure to set the display, for example if "mydesktop" is your desktop hostname DISPLAY=mydesktop:1 xfce4-session &
To have the right click with stylus an easy way is to use the Sebastian Ohl's tslib patch: you can find it here until it will not enter in the official Debian package.
In this way, to get a right click you can simply tap and hold the stylus and after a while a right click will occurs.
Warning: tslib patch is incompatible with xserver-xglamo
.
If you are running Linux (or a similar xorg capable operating system) on your Desktop, you can export your xsession to the openmoko device and use your mouse and keyboard on the Neo screen. A little program called x2x makes it even possible to do this simultaneously on the fly. When activated you just move your mouse to the edge of your monitor and then the mouse cursor continues on the screen of your openmoko device. If you select a window on the OM, the input of your keyboard is automatically entered in that window. You can even use the clipboard to copy data from tour desktop to OM and in the reverse direction.
Configure your desktop computer to export your xsession: On your desktop (with root permissions): Make sure that sshd is installed and in /etc/ssh/sshd_config you have set X11Forwarding yes
In K/Ubuntu sshd is in the package openssh-server.
On your OM device install x2x (with root permissions) apt-get install xauth x2x Now open a new X terminal on your desktop computer. You MUST be the same user that is running the xsession on your desktop (i.e. do not su to root or another user in your x terminal!). Use the same username that is running an xsession on your OM device. Assuming that you have a usb networking connection to OM (with standard configuration) on the user prompt of your desktop type: user@desktop:~$ ssh -X openmoko@192.168.0.202 "/usr/bin/x2x -east -to :0.0" Hit return and enter your password. The xterm window will be unresponsive after that, but keep it open until you disconnect your OM device.
Now move your mouse cursor across the right edge of your monitor. It should enter the screen of your OM device from the left. Of course you can also use -west, -north or -south, depending on your preference where you place your OM.
If computer says: sh: /usr/X11R6/bin/xauth: No such file or directory X11 connection rejected because of wrong authentication. x2x - error: can not open display localhost:11.0
It means you haven't installed xauth on your OM. So on your OM (with root permissions) apt-get install xauth
With this method you can have the following functionality:
All devices/computers in question should be able to install synergy. Windows computers can use an installer exe. Debian devices have a package ready to be used.
apt-get install synergy quicksynergy
quick synergy will appear in your XFCE programs menu (Accessories->QuickSynergy). Run it, switch to the "Use" tab, enter the IP address of the computer with the mouse and keyboard you wish to use, and press Execute.
In the windows host, (or linux) run the synergy after installation, and configure it to share its keyboard and mouse(server), configuration is fairly simple, you add all the hostnames of the devices/computers that ever would be joined to the "screens" list, and create 2 links for each connection.
If your desktop's hostname is homepc, and the device's is debian_gta02, and i place the device to the left of the desktop, the links would look like this:
homepc is right of debian_gta02 debian_gta02 is left of homepc
Now move back to the main screen, and press Start.
That should be it, in windows you should have an icon with a yellow lightning in it when synergy is connected and working. Synergy supports connection of more then one screen so one could set up a full lab with only one keyboard and mouse :)
Debian is supported on the linux to go smartphone mailing list
Whenever you get a segmentation fault while using apt-get or aptitude, clean the database so it will rebuild it rm /var/cache/apt/*.bin
The point of debian on the freerunner is that you get a huge army of software in a repository, all compiled for the arm processor.
Debian is used on many other embedded devices too and so there's a much larger repository of software already available than in the 2008.8 opkg archives.
You can build your own things without need to play with openembedded.
For example compiling natively is a snap w/ debian, just apt-get gcc&libc-dev (on gentoo too) and not so easy w/ om images :) (borked compiler, borked headers).