Skip to content
drinkcat edited this page Aug 6, 2014 · 35 revisions

Sysrq

Chrome/Chromium OS enables sysrq functionality on the F10/Volume Up key when the system is put in developer mode. This behavior is reflected in crouton chroot environments and the Alt+F10/Volume Up key combination will be intercepted and interpreted as Alt+sysrq.

Chromebook keyboard model

Installing crouton's keyboard target provides an xkb overlay that provides similar functions to bindings found in Chromium OS:

sudo sh -e ~/Downloads/crouton -t keyboard -u

Chromium OS key bindings can be inspected by typing Ctrl+Alt+/ (or whatever key is directly next to the right Shift key):

  • All Search+key bindings are supported, with the difference that the top row (function keys) maps to F1->F10 by default. Search+function keys map to actual functions (navigation, brightness, volume, etc.).
  • The other bindings (Ctrl+key, Alt+key, ...) are not supported, and will probably never be, as they may interfere with useful key combinations in some Linux applications.

non-US layout

Non-US layout can be setup by typing: setxkbmap -layout de (replace de by your layout). Some layouts also need to specify a variant, e.g. setxkbmap -layout ch -variant fr. This command needs to be run every time the chroot X server is started (you may want to put it in your window manager startup script).

Non-US layouts are compatible with the Chromebook keyboard model, so you still get Search+key bindings.

Super_L key

Without the keyboard target, the Search key maps to Super_L, after installing the target, it becomes the overlay key (Overlay1_Enable), that allows you to use Search+key combos.

Some window managers require a Super_L key, so you can work around this issue by remapping either Super_L or Overlay1_Enable to another key.

For example, to use Left Alt as overlay key, and Search key as Super_L:

xmodmap -e "keycode 133 = Super_L"
xmodmap -e "keycode 64 = Overlay1_Enable"

or, to keep the Search key as overlay, but use Left Alt as Super_L (the first line is not needed if you have not modified the keyboard map before, as keycode 133 maps to Overlay1_Enable by default):

xmodmap -e "keycode 133 = Overlay1_Enable" # Not needed on "fresh" keymap
xmodmap -e "keycode 64 = Super_L"

You can figure out keycodes for all keys by looking at the output of xev. But DO NOT remap keycode 134 (normally mapped to Super_R) to Overlay1_Enable: it won't work (see issue #362).

xmodmap modifications are lost when you restart the X server, so you should put these in a script that is sourced at session startup. The easiest is to put these commands in a custom shell script, and add the script to the auto-start list of your DE (e.g., instructions for XFCE)

Swap Left Control and Search key

Swapping left control with the Search key requires an extra step, as the modifier table also needs to be modified:

xmodmap -e "keycode 133 = Control_L"
xmodmap -e "keycode 37 = Overlay1_Enable"
xmodmap -e "add control = Control_L"
xmodmap -e "remove control = Overlay1_Enable"

This may apply to other keys as well, have a look at the output of xmodmap before and after swapping the keys, to see if you need to apply a similar trick in your case.

Unity/Gnome resets xmodmap customization and keyboard layout

For some reason, Unity (and possibly Gnome) resets the keyboard layout everytime the user switches to Chromium OS and back (#953).

As a workaround, you can disable keyboard layout management in Gnome with:

gsettings set org.gnome.settings-daemon.plugins.keyboard active false

However, this will break the layout switching widget.

Remove the keyboard model

If you install the keyboard target, but then realise a standard keyboard layout is preferable for your use case, you can remove the target by removing its entry from /etc/crouton/targets, then running:

sudo apt-mark unhold xkb-data
sudo apt-get -y install --reinstall xkb-data

Outstanding issues

The keyboard layout works well in most situations, but there are a few outstanding issues, that do not have a simple solution:

  • There is no good way to bind shortcuts to "Search+letter" combos. (There is an ugly hack in #267, but we do not want to ship that by default)
  • We are able to swap Search key with another key (see this page), but NOT Super_R, for some unknown reason. (#362)
  • Currently, Search+Alt toggles Caps lock. This is the reverse of Chromium OS, which uses Alt+Search. (this is easy to fix, actually)
  • It would be nice to make it possible to configure if F1/F12 or function keys are the default (#665)
  • Search key alone does not do anything (#665)
  • Unity (and possibly Gnome) resets the keyboard layout everytime the user switches to Chromium OS and back (#953).

Extra key bindings

xbindkeys is loaded in the chroot X server, to allow commands to be executed when certain key combination is pressed (e.g. Ctrl+Alt+Back/Forward to switch between Chromium OS and the chroot display). .xbindkeysrc.scm in the user home directory is also loaded, if it exists, allowing to add custom bindings.

The configuration file is based on Scheme/Guile, and an example configuration file can be generated with xbindkeys -dg.

After modifying ~/.xbindkeysrc.scm, you need to restart the chroot X server (pkill -SIGHUP xbindkeys may not always work).

You can debug syntax errors by running:

METHOD='x11' xbindkeys -fg /etc/crouton/xbindkeysrc.scm -v,

replacing x11 by xephyr if you are using Xephyr (ARM or explicit choice)

Map Alt+Click to middle button

Getting a middle click is tricky, especially on the Samsung ARM Chromebook: it requires quite a bit of skill to get 3 fingers down on the trackpad at the same time, and sometimes a right click is generated instead.

If your window manager or applications do not require Alt+Click for any other purpose, you can map it to generate a middle button click:

; Add to ~/.xbindkeysrc.scm
; Map Alt+click to middle button
; Map on Release so that it does not appear both buttons are pressed
(xbindkey '(release alt "b:1") "xdotool click --clearmodifiers 2")

A python script for adding brightness hotkeys

https://gist.github.com/ubershmekel/6626111

volume scripts

Clone this wiki locally