kmscon/TODO
David Herrmann bb9089696e Add K_OFF to vt-TODO
See https://github.com/dvdhrm/kmscon/pull/3 for a discussion of K_OFF in the VT
subsystem. We cannot apply it now but we have to reconsider it when the input
subsystem has been written.

Signed-off-by: David Herrmann <dh.herrmann@googlemail.com>
2011-12-14 15:38:26 +01:00

49 lines
2.3 KiB
Plaintext

= This is a rough TODO list, feel free to contribute patches =
Output Subsystem:
- Test whether eglMakeCurrent() is thread-aware and can set different context
per thread. Comment this behaviour in kmscon_compositor_use().
Multiple active context would actually make sense if you have multiple
graphic cards as you could render on both cards simultaneously. However, if
you have only one card, multiple active contexts are not really needed.
- Avoid EGL_EGLEXT_PROTOTYPES and GL_GLEXT_PROTOTYPES and instead retrieve
function pointers dynamically.
- How to get bpp and colordepth?
- Retrieve DRI card from udev or at least make kmscon_compositor_new() accept a
path to the DRI card so the user can have udev provide the path.
- Check whether drmSetMaster() is needed. It can only be called with root
priviledges and all my tests worked without it. What are the benefits of
calling this?
- Whats the difference between connector and encoder? Or why are encoders
needed at all? The output selection logic simply tries to find the first
encoder that provides an available crtc. Should we replace this logic with an
additional list of available crtcs so users can choose them, too?
- Is glFinish() needed before setCrtc or is glFlush sufficient?
Console Subsystem:
- Do we need to offer a way to create mipmaps of the cairo image? This would
allow faster mappings of the console onto the framebuffers.
- We need to correctly handle Unicode characters. Every console cell contains
one single character, however, Unicode supports combining marks. Our
implementation supports them but we need to correctly map our keyboard input
to the correct cells. Pango depends on glib so we can probably use the glib
functions for UTF-8/Unicode handling.
- Add glyph caching support with cairo_scaled_font_t. The libvte does this
inside vtedraw.c but it is licensed by GPL so we need to rewrite it if we
want it.
This would speed up our font-draw functions considerably as we would bypass
pango if a glyph is already in the hash-table.
VT Subsystem:
- Set KDSKBMODE to K_OFF to avoid getting input from the VT subsystem. This
also discards the VT-switch events so we should first implement our own
VT-switching mechanisms and then use this K_OFF switch.