Implementation of simplified low-level API. More...
#include <sys/mman.h>
#include <fcntl.h>
#include <liberipc/eripc.h>
#include <liberipc/eripcbusyd.h>
#include <liberipc/eripctoolbar.h>
#include <liberipc/eripcviewer.h>
#include <liberdm/display.h>
#include <liberdm/erdm.h>
#include "iliad_api.h"
Functions | |
erClientChannel_t | busyd_channel () |
IPC channel for communication with busy LED daemon. | |
int | set_led (int state) |
Set state of busy LED. | |
erClientChannel_t | toolbar_channel () |
IPC channel for communication with toolbar. | |
int | init_icons (int *iconlist) |
Set icons to show on toolbar. | |
erClientChannel_t | pagebar_channel () |
IPC channel for communication with pagebar. | |
int | init_pagebar (int npages, int page, int pagepos, int zoom) |
Initialise pagebar. | |
int | set_pagebar_page (int page, int pagepos) |
Set current page and position for pagebar. | |
unsigned char * | framebuffer () |
Map screen framebuffer device into memory. | |
void | unmap_framebuffer () |
Unmap screen framebuffer device from memory. | |
void | update_now4bit () |
Update the display with 4-bit quality within 0.1 seconds. | |
int | update_display (int quality, int priority) |
Update the iLiad's display. | |
void | clear_display () |
Clears the display within 0.1 seconds. | |
Variables | |
static unsigned char * | fb0_map |
Implementation of simplified low-level API.
Inter-process communication (with LED daemon, toolbar and pagebar) is performed by one function opening the channel on demand and other functions sending an appropriate message. The framebuffer mapping and screen update functions are just wrappers. Argument and return value constants are defined in iliad_api.h.
erClientChannel_t busyd_channel | ( | ) |
IPC channel for communication with busy LED daemon.
The IPC client is started when this function is first called, the cached channel data is returned on subsequent calls.
unsigned char* framebuffer | ( | ) |
Map screen framebuffer device into memory.
Opens and maps the framebuffer device /dev/fb0 on demand and henceforth returns a pointer to the mapped region. The organisation of the framebuffer is one byte per pixel, row major.
int init_icons | ( | int * | iconlist | ) |
Set icons to show on toolbar.
Creates toolbar icon set from scratch.
iconlist | Pointer to integer array indicating desired icons. The least significant byte must contain the icon ID according to the e_iconID_t enum, the next more significant byte the icon state according to the e_iconState_t enum. The list must be concluded with a -1. |
int init_pagebar | ( | int | npages, | |
int | page, | |||
int | pagepos, | |||
int | zoom | |||
) |
Initialise pagebar.
This function resets the page bar, sets the number of pages to display, the current page, the position on the current page (if applicable) and the page bar mode.
npages | Number of pages the page bar should display | |
page | Current page, 1-based | |
pagepos | If >= 0, this is the position on the current page in percent, which is displayed as a narrow black bar at the bottom of the rounded rectangle representing the current page. | |
zoom | Determines what the pagebar displays when the number of pages is so large that not all of them can be displayed as rounded rectangles. If 1, only the pages neighbouring the current one are displayed, all as rounded rectangles. If 0, the current, first and last pages are displayed as rectangles, while those in between are indicated by a series of vertical lines. |
erClientChannel_t pagebar_channel | ( | ) |
IPC channel for communication with pagebar.
The IPC client is started when this function is first called, the cached channel data is returned on subsequent calls.
int set_led | ( | int | state | ) |
Set state of busy LED.
state | LED_OFF, LED_BLINK or LED_ON |
int set_pagebar_page | ( | int | page, | |
int | pagepos | |||
) |
Set current page and position for pagebar.
page | Current page, 1-based | |
pagepos | If >= 0, this is the position on the current page in percent, which is displayed as a narrow black bar at the bottom of the rounded rectangle representing the current page. |
erClientChannel_t toolbar_channel | ( | ) |
IPC channel for communication with toolbar.
The IPC client is started when this function is first called, the cached channel data is returned on subsequent calls.
int update_display | ( | int | quality, | |
int | priority | |||
) |
Update the iLiad's display.
The reason for the existence of these two parameters is undocumented by iRex. Possibly higher qualities and priorities are more power-intensive.
quality | Quality (bit accuracy) of the update | |
priority | Priority determining the delay until the update will be performed (this function returns immediately in any case) |
void update_now4bit | ( | ) |
Update the display with 4-bit quality within 0.1 seconds.
This is a convenience function which merely calls update_display(DISP_4BIT, DISP_01SEC).