- 
                Notifications
    You must be signed in to change notification settings 
- Fork 120
Framebuffer input-handling improvements #737
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: Cog
Are you sure you want to change the base?
Conversation
… support e.g. thinkpad trackpads in framebuffer mode
| Oh thats neat! | 
| Hi Tony, well that’s great because there is a better way available to test. The threaded FFI VM (see the various [gcc3x-]cointerpmt.c files) is currently being used in anger at LabWare. There is a functional threaded ODBC connect and an in progress socket library. I believe both will be released open source. So the possibility exists to interface directly to the event system using the FFI and callbacks since one can now make a blocking call for the next event in one thread while the VM continues to execute Smalltalk in other threads. Currently build setups exist only for macOS. But it’s simple. One uses [gcc3x-]cointerpmt.c in place of [gcc3x-]cointerp.c and defines COGMT=1 on the c compiler command line. One would add buildmt, buildastmt & builddbgmt directories alongside build et al. The basic scheme is that FFI calls block the entire vm until the next heartbeat (currently 500hz, but could be higher freq) at which time the vm spawns another thread to run Smalltalk if blocked in an FFI call. The FFI thread on its return path and any new thread race to control the vm. Above that one can bind Smalltalk processes to threads using the threadAffinity inst var. The VM’s thread scheduler will switch threads if necessary in process switch. There are a few more details. So the threaded vm provides the necessary infrastructure to connect Smalltalk directly to the GUI subsystem. | 
| 
 That is wonderful news! I'll look forward to it. However, the VM today is in good enough shape to allow the image to reach out and use  This PR (still, I suppose, WIP) is instead intended to allow current Trunk images to work on framebuffer systems with a trackpad. For that, alterations to the C are both necessary and evil... | 
Hi Eliot, all,
Working recently with a stripped-down Alpine installation on an oldish Thinkpad (X240) with a touchpad, I found the framebuffer input handling support did not work. The core issue is that
/dev/input/event*for the touchpad yieldsABS_*events, notREL_*events.This branch makes a few changes to (a) very slightly clean up and (b) improve
/dev/inputhandling in the framebuffer driver.Potential improvements:
Ultimately it's a bit of a shame this is done in C; I've had good results reading
/dev/inputdirectly from Squeak (for the Squeakphone), so I'd be interested in discussing ways we could lift more of Squeak's event handling into the image. Until then of course it'd be nice to improve the C support code we have. Thoughts welcome!