Date: Mon, 12 Feb 2007 08:02:54 -0800 From: "Jordan Sissel" <psionic@gmail.com> To: "Alexander Leidinger" <Alexander@leidinger.net> Cc: Daniel Eischen <deischen@freebsd.org>, "Eugene M. Kim" <freebsd.org@ab.ote.we.lv>, hackers@freebsd.org Subject: Re: sin()/cos()/tan() for kernel code? '_ 'a Message-ID: <5ad23a300702120802n19d4c32byed16dbad291135be@mail.gmail.com> In-Reply-To: <20070212101632.qa3p4f5wkkoccsk0@webmail.leidinger.net> References: <45CED641.7020608@ab.ote.we.lv> <Pine.GSO.4.64.0702110941580.19880@sea.ntplx.net> <20070211110815.O62469@math.missouri.edu> <20070211115815.O62469@math.missouri.edu> <20070212101632.qa3p4f5wkkoccsk0@webmail.leidinger.net>
next in thread | previous in thread | raw e-mail | index | archive | help
As it stands right now, moused is not the proper place for this. sysmouse(4) only speaks relative coordinates and has no idea about absolute positioning that have the opportunity of doing with tablets and touchpads. I highly recommend this be implemented as an X driver, unless you have no intention of using your tablet in X. In X, you can specify your driver gives absolute positioning. There's also an existing wacom driver for X which may provide some/all of the functionality you need. IMO, there's no reasonable gain in doing complex mouse drivers in the kernel. For one, you'd have to have it speak a protocol X (assuming again that you're using X) understands. -Jordan On 2/12/07, Alexander Leidinger <Alexander@leidinger.net> wrote: > > Quoting Stephen Montgomery-Smith <stephen@math.missouri.edu> (from > Sun, 11 Feb 2007 12:00:12 -0600 (CST)): > > > > > > > On Sun, 11 Feb 2007, Stephen Montgomery-Smith wrote: > > > >> > >> > >> On Sun, 11 Feb 2007, Daniel Eischen wrote: > > >>> Can't you do this in userland? Teach moused? > >> > >> Since you will only need sin and cos evaluated to the nearest > >> degree, if that, I suggest a simple look up table. There is also > >> something called the CORDIC method, I think, but I suspect that the > >> look up table will be so much easier to program, and negligable > >> extra space overhead. > >> > >> Stephen > > > > And if you do need more accuracy than the nearest degree, the formulae > > > > sin(x+h) = sin(x) + h cos(x); > > cos(x+h) = cos(x) - h sin(x) > > > > for small h (say |h| less than half a degree) should provide way more > > accuracy than you should need. > > There's work underway which moves the hard work of the mouse drivers > from the kernel to moused. The kernel just has a simple hardware > interface there, and the real interpretion of all the stuff from the > mouse happens in the userland. > > See http://www.semicomplete.com/projects/newpsm/ for more. > > So maybe it would be better to implement this in moused right from the > beginning... > > Bye, > Alexander. > > -- > Love is never asking why? > > http://www.Leidinger.net Alexander @ Leidinger.net: PGP ID = B0063FE7 > http://www.FreeBSD.org netchild @ FreeBSD.org : PGP ID = 72077137 > _______________________________________________ > freebsd-hackers@freebsd.org mailing list > http://lists.freebsd.org/mailman/listinfo/freebsd-hackers > To unsubscribe, send any mail to "freebsd-hackers-unsubscribe@freebsd.org" > >
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?5ad23a300702120802n19d4c32byed16dbad291135be>