OpenCloudOS-Kernel/drivers/staging/frontier
Harvey Harrison d599edcaea staging: __FUNCTION__ is gcc-specific, use __func__
Signed-off-by: Harvey Harrison <harvey.harrison@gmail.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2009-01-07 15:48:54 -08:00
..
Kconfig Staging: add frontier tranzport and alphatrack drivers 2009-01-06 13:52:36 -08:00
Makefile Staging: add frontier tranzport and alphatrack drivers 2009-01-06 13:52:36 -08:00
README Staging: add frontier tranzport and alphatrack drivers 2009-01-06 13:52:36 -08:00
TODO Staging: add frontier tranzport and alphatrack drivers 2009-01-06 13:52:36 -08:00
alphatrack.c staging: __FUNCTION__ is gcc-specific, use __func__ 2009-01-07 15:48:54 -08:00
alphatrack.h Staging: frontier: fix compiler warnings 2009-01-06 13:52:36 -08:00
frontier_compat.h Staging: add frontier tranzport and alphatrack drivers 2009-01-06 13:52:36 -08:00
surface_sysfs.h Staging: add frontier tranzport and alphatrack drivers 2009-01-06 13:52:36 -08:00
tranzport.c staging: __FUNCTION__ is gcc-specific, use __func__ 2009-01-07 15:48:54 -08:00

README

This directory contains the USB Tranzport and Alphatrack Kernel drivers for Linux.

At present the tranzport does reads/writes of 8 byte cmds to /dev/tranzport0 to control
the lights and screen and wheel

At present the alphatrack accepts reads/writes of 12 byte cmds to /dev/tranzport0 to control
the lights and screen and fader.

Both drivers also have some sysfs hooks that are non-functional at the moment.

The API is currently closely tied to the ardour revision and WILL change.

A sysfs interface is PERFECT for simple userspace apps to do fun things with the
lights and screen. It's fairly lousy for handling input events and very lousy
for watching the state of the shuttle wheel.

A linux input events interface is great for the input events and shuttle wheel. It's
theoretically OK on LEDs. A Fader can be mapped to an absolute mouse device.
But there is no LCD support at all.

In the end this is going to be driven by a midi layer, which handles all those
cases via a defined API, but - among other things - is slow, doesn't do
flow control, and is a LOT of extra work. Frankly, I'd like to keep the
core driver simple because the only realtime work really required is
the bottom half interrupt handler and the output overlapping.

Exposing some sort of clean aio api to userspace would be perfect. What that
API looks like? Gah. beats me.