[PATCH] Fix function keys sequence on USB
Dinar Valeev
k0da at opensuse.org
Tue Jun 2 20:43:16 AEST 2015
On Tue, Jun 2, 2015 at 12:29 PM, Nikunj A Dadhania
<nikunj at linux.vnet.ibm.com> wrote:
> Dinar Valeev <k0da at opensuse.org> writes:
>
>> On Tue, Jun 2, 2015 at 11:47 AM, Nikunj A Dadhania
>> <nikunj at linux.vnet.ibm.com> wrote:
>>> Dinar valeev <k0da at opensuse.org> writes:
>>>> @@ -262,7 +258,7 @@ static void check_key_code(uint8_t *buf)
>>>> case 0x43:
>>>> write_key(0x1b); /* F10 */
>>>> write_key(0x5b);
>>>> - write_key(0x31);
>>>> + write_key(0x32);
>>>> write_key(0x31);
>>>> write_key(0x7e);
>>>> break;
>>>
>>> Does F10 work for you? doesn't work for me ?
>> It does. But then menu entry is expanded to openSUSE, with Linux 4.0.1-1-default
>> entering edit mode and pressing f10 finally boots it.
>>
>> xterm sequence is ^[[21~
>
> I had used following in TCG:
>
> qemu-system-ppc64 -machine pseries -m 2G -serial stdio -cdrom distro.iso \
> -vnc :1
>
>>
>>
>>>
>>>> @@ -270,7 +266,7 @@ static void check_key_code(uint8_t *buf)
>>>> case 0x44:
>>>> write_key(0x1b); /* F11 */
>>>> write_key(0x5b);
>>>> - write_key(0x31);
>>>> + write_key(0x32);
>>>> write_key(0x33);
>>>> write_key(0x7e);
>>>> break;
>>>> @@ -278,7 +274,7 @@ static void check_key_code(uint8_t *buf)
>>>> case 0x45:
>>>> write_key(0x1b); /* F12 */
>>>> write_key(0x5b);
>>>> - write_key(0x31);
>>>> + write_key(0x32);
>>>> write_key(0x34);
>>>> write_key(0x7e);
>>>> break;
>>>> @@ -290,36 +286,34 @@ static void check_key_code(uint8_t *buf)
>>>> case 0x49:
>>>> write_key(0x1b); /* INS */
>>>> write_key(0x5b);
>>>> - write_key(0x31);
>>>> + write_key(0x32);
>>>> write_key(0x7e);
>>>> break;
>>>>
>>>> case 0x4a:
>>>> write_key(0x1b); /* HOME */
>>>> write_key(0x5b);
>>>> - write_key(0x32);
>>>> - write_key(0x7e);
>>>> + write_key(0x48);
>>>
>>> Looking at accept.fs - handle-ESC-5b ...
>>>
>>> : handle-ESC-5b
>>> key
>>> dup 31 = IF \ HOME
>>> key drop ( drops closing 7e ) handle-^A
>>> ELSE
>>> dup 33 = IF \ DEL
>>> key drop handle-^D
>>> ELSE
>>> dup 34 = IF \ END
>>> key drop handle-^E
>>> ELSE
>>> dup 1f and handle-CSI
>>> THEN
>>> THEN
>>> THEN drop
>>> ;
>>>
>>>
>>> ... following change is sufficient:
>>> - write_key(0x32);
>>> + write_key(0x31);
>>>
>> Home sequence for me is: ^[[H
>
> Can you check the above change in your setup ?
That works as well.
>
>>>
>>>> break;
>>>>
>>>> case 0x4b:
>>>> write_key(0x1b); /* PgUp */
>>>> write_key(0x5b);
>>>> - write_key(0x33);
>>>> + write_key(0x35);
>>>> write_key(0x7e);
>>>> break;
>>>>
>>>> case 0x4c:
>>>> write_key(0x1b); /* DEL */
>>>> write_key(0x5b);
>>>> - write_key(0x34);
>>>> + write_key(0x33);
>>>
>>> Right.
>>>
>>>> write_key(0x7e);
>>>> break;
>>>>
>>>> case 0x4d:
>>>> write_key(0x1b); /* END */
>>>> write_key(0x5b);
>>>> - write_key(0x35);
>>>> - write_key(0x7e);
>>>> + write_key(0x46);
>>>
>>> I tried using: 0x34, but somehow it does not work.
>> ^[[F works for me.
>>
>> All changes are tested in openSUSE's grub2 with -vga std. Note we
>> don't have any special patches here..
>>
>> Tested with -vga none -nographic. Home, End works with patched SLOF
>
> Ok.
>
> Regards
> Nikunj
>
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev at lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/linuxppc-dev
More information about the Linuxppc-dev
mailing list