On Wed, Sep 20, 2006 at 12:14:04AM +0200, Marius Strobl wrote:
> On Wed, Sep 20, 2006 at 01:56:05AM +0400, Ruslan Ermilov wrote:
> > 
> > The proper fix would be to fix the kernel to pass an argument by
> > value, like the userland does.  But from the practical point of
> > view, it may make sense to change the API and say that these
> > IOCTLs now take a pointer type argument.  I'm not sure.  If you
> > know of any applications (mine test util not counting :-) that
> > use KDSKBMODE/KDSETLED/KDSKBSTATE, then we should probably fix
> > the kernel callers.
> 
> XFree86/Xorg use KDSKBMODE and KDSETLED, see f.e. the Xorg
> "kbd" driver:
> http://webcvs.freedesktop.org/xorg/xserver/xorg/hw/xfree86/os-support/bsd/bsd_kbd.c?revision=1.8&view=markup
> 
Hmm, but they don't work on sparc64.  How X.Org ever works then?
I remember installing it on my sparc64 laptop...

: # uname -p
: sparc64
: # cat a.c
: #include <sys/kbio.h>
: #include <sys/ioctl.h>
: #include <err.h>
: #include <stdio.h>
: #include <stdlib.h>
: 
: int
: main(void)
: {
:         int mode;
: 
:         mode = K_CODE;
:         if (ioctl(0, KDSKBMODE, mode) == -1)
:                 err(1, "ioctl(KDSKBMODE)");
: 
:         if (ioctl(0, KDGKBMODE, &mode) == -1)
:                 err(1, "ioctl(KDGKBMODE)");
:         printf("current mode = %d, should be %d\n", mode, K_CODE);
: 
:         exit (0);
: }
: # ./a < /dev/vkbdctl0
: current mode = 0, should be 2
: # 


Cheers,
-- 
Ruslan Ermilov
[EMAIL PROTECTED]
FreeBSD committer

Attachment: pgpJ6LXgNG1vN.pgp
Description: PGP signature

Reply via email to