[Zaurus-devel] new Xorg X server + XKB keymap for Zaurus

2010-01-19 Thread Stanislav Brabec
I just got partial success with migration of Zaurus to the latest Xorg.

Here is the result of my experiments (WIP):
ftp://ftp.penguin.cz/pub/users/utx/zaurus/files/xserver-xorg/

Before you test, you have to do (on Angstrom):
- Install xorg and its modules.
- Disable all xmodmap commands in /etc/X11/Xinit.d.
- Edit your preferred keymap in /etc/X11/Xinit.d/02xorg (cz is default
  there!)
- Fix /etc/X11/Xserver to start Xorg without kdrive specific arguments.
  Only -dpi is relevant.
- Disable chvt on Fn+Arrows.
- Copy files and apply the patch.

New features:
Right Ctrl (on Hankaku_Zenkaku) + numbers = F-keys
Fn+Tab = Caps works
Left Alt is on Hiragana_Katakana as it was in past

Fn+z = Insert
Fn+x,c,v generates XF86Cut/Copy/Paste (file for GTK+ is here:
ftp://ftp.penguin.cz/pub/users/utx/zaurus/files/keyboard/homedir/DOT.gtkrc-2.0 )
Fn+0 switches group
Fn+d = `
Fn+Arrows generates PgUp, PgDn, Home, End

Todo:
- Implement chvt to the keymap.
- Migrate touchscreen to evdev or fix tslib driver crash on chvt.
- XRandR is not yet supported.
- Some operations are much slower than they were on kdrive.
- Adapt daemons to new key codes.
- Think again about keymaps that need AltGr+Numbers (cz). What should
  take precedence? Move Brightness or AltGr+Number to Fn+Shift? Or move
  it elsewhere?
- Think about use of unused keys.
- Implement Compose.
- How to discriminate OK, OK, Enter and Esc, Cancel.
- Maybe set slower repeat rates for some special keys instead of turning
  it off.
- XKB geometry



Stanislav Brabec
http://www.penguin.cz/~utx/zaurus


___
Zaurus-devel mailing list
Zaurus-devel@lists.linuxtogo.org
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/zaurus-devel


Re: [Zaurus-devel] new Xorg X server + XKB keymap for Zaurus

2010-01-19 Thread Yuri Bushmelev
Hello!

> I just got partial success with migration of Zaurus to the latest Xorg.

Thank you for your work!
Can you please measure memory load? Just to compare kdrive vs xorg.

> Todo:
> - Implement chvt to the keymap.
> - Migrate touchscreen to evdev or fix tslib driver crash on chvt.
> - XRandR is not yet supported.
> - Some operations are much slower than they were on kdrive.

What are that operations?

> - Adapt daemons to new key codes.
> - Think again about keymaps that need AltGr+Numbers (cz). What should
>   take precedence? Move Brightness or AltGr+Number to Fn+Shift? Or move
>   it elsewhere?

May be map them just to Alt+Number? Or you can use Calendar or Menu key e.g. 
as modificator. Or just remove brightness bindings for keymaps with 
AltGr+Number.

> - Think about use of unused keys.
> - Implement Compose.

Same thing here. I'll prefer using Calendar - Menu keys for this.

> - How to discriminate OK, OK, Enter and Esc, Cancel.
> - Maybe set slower repeat rates for some special keys instead of turning
>   it off.
> - XKB geometry

How are (should be?) mapped wheel, screen keys and functional keys 
(Calendar/Address/Mail/Home/Menu)?

Seems I should prepare russian phonetic keymap too :)

-- 
Yuri Bushmelev

___
Zaurus-devel mailing list
Zaurus-devel@lists.linuxtogo.org
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/zaurus-devel


Re: [Zaurus-devel] new Xorg X server + XKB keymap for Zaurus

2010-01-19 Thread Stanislav Brabec
Yuri Bushmelev wrote:

> Thank you for your work!
> Can you please measure memory load? Just to compare kdrive vs xorg.

Yes, I can.

> > Todo:
> What are that operations?

> > - Implement chvt to the keymap.
Several lines in the keymap.

> > - Migrate touchscreen to evdev or fix tslib driver crash on chvt.

Find what is broken on touchscreen support (I seen a patch somewhere).
It may require upgrade to the latest kernel (click seems to not being
generated by old kernels).

> > - XRandR is not yet supported.

Rotation is supported only when server starts using ShadowFB. But X
thinks that hardware supports rotation, fbdev driver on Zaurus can't.

The code to support software based rotation on fly is missing.

> > - Some operations are much slower than they were on kdrive.

It seems that some operations are performed on unrotated buffer, which
introduces inefficient random access to SDRAM. It seems to be filling
screen and block move.

Maybe comparing with kdrive code could help.

> > - Adapt daemons to new key codes.

Use keycodes that should be used. Don't force its own hardwired xmodmap
commands (gpe-dm does).

> > - Think again about keymaps that need AltGr+Numbers (cz). What should
> >   take precedence? Move Brightness or AltGr+Number to Fn+Shift? Or move
> >   it elsewhere?
> 
> May be map them just to Alt+Number?

It may conflict with Alt+Number hotkeys. (Well Alt+Fn+Number may cause
problems as well, but they are a bit more rare.)

> Or you can use Calendar or Menu key e.g. 
> as modificator.

It might be possible. Now I use always Fn+3/4 for brightness and Fn
+Shift+3/4 for #/$ in cz and Shift+3/4 for #/$ in us.

> Or just remove brightness bindings for keymaps with 
> AltGr+Number.

Brightness binding should be somewhere. I would prefer following printed
symbols as far as possible. It's easier to type then. I would hardly
imagine having different brightness-up in "us" and "cz" keymaps.

I was using LAlt+3/4 for brightness in cz map in past, but then I
returned to Fn+3/4. I am not sure what is better. In both cases I made
mistakes - once typing "$", second type while raising brightness.

> > - Think about use of unused keys.
> > - Implement Compose.
> 
> Same thing here. I'll prefer using Calendar - Menu keys for this.

Well, I would think about keeping PIM symbols there (for people who like
PIM) or map there important window manager actions for people that don't
like PIM (as an alternate map).

I was mapping WM actions there in past: Rotate windows, Close window,
Show Desktop/Menu. It was very comfortable - I didn't have to pick my
stylus often.

> > - How to discriminate OK, OK, Enter and Esc, Cancel.
> > - Maybe set slower repeat rates for some special keys instead of turning
> >   it off.
> > - XKB geometry
> 
> How are (should be?) mapped wheel,

Not yet, thinking about Fn+RAlt+arrows. RAlt+Arrows to map mouse
movement, RAlt+OK/Esc/something - mouse click.

But I have to learn XKB a lot to be able to do it.

It would mean more work than it sounds. After using of these keys,
cursor must become visible.

Fn+Tab->Caps_Lock is a XKB black magic. Implementing that took many
hours of docs reading and experimenting.

> screen keys

No idea. Well, I had an idea about application-specific GUI mapping to
selected actions (and pop-up with description).

> and functional keys 
> (Calendar/Address/Mail/Home/Menu)?

XF86Calendar, XF86Book, XF86Mail, XF86HomePage, XF86MenuKB.

And F-keys are mapped to RAlt+numbers, but it seems to be half working -
xev reports them, but mc gets only Esc sequences.

> Seems I should prepare russian phonetic keymap too :)

Note that my map is still a subject of changes.


-- 
Stanislav Brabec
http://www.penguin.cz/~utx/zaurus


___
Zaurus-devel mailing list
Zaurus-devel@lists.linuxtogo.org
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/zaurus-devel


Re: [Zaurus-devel] new Xorg X server + XKB keymap for Zaurus

2010-01-20 Thread Stanislav Brabec
Yuri Bushmelev wrote:
> Hello!
> 
> > I just got partial success with migration of Zaurus to the latest Xorg.
> 
> Thank you for your work!
> Can you please measure memory load? Just to compare kdrive vs xorg.

kdrive without args after flush cache:
1.2MB

Xorg with configuration on my page after flush cache:
8.5MB

I am not sure, what eats this memory, but disabling rotation and
shadowfb, or hiding extension did not have any impact to it.

> > Todo:
> > - Implement chvt to the keymap.
Fixed in xf86-input-tslib, worked around in xf86-video-fbdev.

Now it is fully working except calibration. Old calibration does not
work (missing extension), new calibration uses different layer that
cannot calibrate tslib well (guessing that double integer rounding will
happen).




Stanislav Brabec
http://www.penguin.cz/~utx/zaurus


___
Zaurus-devel mailing list
Zaurus-devel@lists.linuxtogo.org
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/zaurus-devel


Re: [Zaurus-devel] new Xorg X server + XKB keymap for Zaurus

2010-01-21 Thread Yuri Bushmelev
Hello!

> > Thank you for your work!
> > Can you please measure memory load? Just to compare kdrive vs xorg.
> 
> kdrive without args after flush cache:
> 1.2MB
> 
> Xorg with configuration on my page after flush cache:
> 8.5MB
> 
> I am not sure, what eats this memory, but disabling rotation and
> shadowfb, or hiding extension did not have any impact to it.

I really hope that this proposal will be sponsored:
http://elinux.org/Decrease_X.org_XFree86_server_footprint

Here is discussion:
http://tree.celinuxforum.org/pipermail/celinux-dev/2009-December/001833.html

This guy is from OpenInkpot project. They have even harder environement 
(smaller NAND and RAM).

-- 
Yuri Bushmelev

___
Zaurus-devel mailing list
Zaurus-devel@lists.linuxtogo.org
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/zaurus-devel


Re: [Zaurus-devel] new Xorg X server + XKB keymap for Zaurus

2010-01-21 Thread Stanislav Brabec
Yuri Bushmelev wrote:
> Hello!
> 
> > > Thank you for your work!
> > > Can you please measure memory load? Just to compare kdrive vs xorg.
> > 
> > kdrive without args after flush cache:
> > 1.2MB
> > 
> > Xorg with configuration on my page after flush cache:
> > 8.5MB

I just did yet another test:
Sum of memory with gpe-dm in Xorg:   18.5MB
Sum of memory with gpe-dm in Xfbdev: 11.7MB

It implies:
6.8MB is unique Xorg memory, 0.5MB is the shared memory (libraries?).

I also tried glxgears: It crashes the server with SIGSEGV.



Stanislav Brabec
http://www.penguin.cz/~utx/zaurus


___
Zaurus-devel mailing list
Zaurus-devel@lists.linuxtogo.org
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/zaurus-devel