This repository has been archived by the owner on Jan 7, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathReleaseNotes
283 lines (232 loc) · 12.4 KB
/
ReleaseNotes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
Intel(R) Automotive Solutions Compositor Overview
-------------------------------------------------
A standard Wayland compositor has 3 high level components:
1) The front-end protocol interface. Client applications use the front-end
protocol to communicate with the compositor. The standard Wayland compositor
package, Weston, provides two front-end protocol implementations; one
designed for desktop environments and one for tablet environments.
2) The core compositor, Weston. This implements the core Wayland protocols.
3) The compositor backend. This interfaces the compositor with the underlying
hardware. The base Weston package provides interfaces for X11 and DRM.
The IAS compositor also includes a fourth component not found elsewhere:
4) The plugin framework. This component allows customers to specify layout and
input plugins via the IAS config file. An 'ias_layout_manager' interface is
exposed to clients to allow them to activate/deactivate layout plugins and
respond to layout changes.
The Intel(R) Automotive Solutions Wayland compositor package provides custom
implementations of the front-end protocol interface and the compositor backend.
These custom implementations provide capabilities that are specifically tailored
to meet the needs of automotive IVI system integrators.
ivi-shell
The IAS compositor adds ivi-shell for GENIVI compatibility. This shell
comprises of 3 separate modueles. They are ivi-shell.so, ivi-layout.so
and hmi-controller.so.
For details on the protocol see the ivi-application.xml and
ivi-hmi-controller.xml
The following interfaces are supported:
ivi_surface
destroy
[event] visibility
[event] configure
ivi_application
surface_create
ivi_hmi_controller
UI_ready
workspace_control
switch_mode
home
[event] workspace_end_control
ias-shell
The ias-shell has been designed to provide a client protocol tailored to
automotive IVI system needs. It is not compatible with the Weston desktop
or tablet shells and thus does not support clients that depend on desktop
or tablet specific features.
For details on the protocol see the ias-shell.xml file.
The following interfaces are supported:
ias_shell
set_background
set_zorder
set_parent
set_behavior
popup
get_shell_surface
[event] configure
ias_layout_manager
set_layout
[event] layout
[event] layout_switched
ias_hmi
set_constant_alpha
move_surface
resize_surface
zorder_surface
set_visible
[event] surface_info
The Weston configuration file, weston.ini, specifies which protocol will be
used. To specify that the ias-shell protocol is used make sure your
weston.ini contains these lines:
[core]
shell=ias-shell.so
To use ivi-shell.so, change the above line to say:
shell=ivi-shell.so
The ias-shell supports loading a custom client that is privileged and can
control some aspects of client layout. This is similar to the desktop-shell
and desktop-shell client where the desktop-shell client may present a
global menu bar and desktop menus to launch other client applications.
There is some overlap in functionality between with the ias-shell client
and layout plug-ins.
The ias-shell's configuration is controlled by the ias.conf XML file. This
file is located in the directory as the weston.ini file. The ias.conf file
contains a section, <shell>, that defines the controller application.
For example:
<shell>
<hmi exec='path_to_hmi_application' />
</shell>
ias-backend
The Intel(R) Automotive Solutions compositor backend module is what enabled
the use of layout plug-ins and provides the interface to the Intel(R) EMGD
kernel mode driver. It makes use of specific capabilities of the
Intel(R) EMGD driver. The backend module will also work with the standard
i915 kernel mode driver but the following capabilities will not function:
- multiplane support (sprite planes)
- frame buffer gamma correction
- frame buffer contrast adjustment
- frame buffer brightness adjustment
<backend depth='1' stencil='1' raw_keyboards='1'>
<startup>
<crtc name='HDMI1' model='classic' mode='preferred'>
<output name='HDMI1-0' size='inherit' position='origin' />
</crtc>
<crtc name='HDMI2' model='flexible' mode='preferred'>
<output name='HDMI1-0' size='inherit' position='origin' />
<output name='LEFT' size='scale:400x400' position='rightof'
target='HDMI1-0' plane_position='10,10' plane_size='600x800' />
<output name='RIGHT' size='inherit' position='rightof'
target='LEFT' plane_position='620,10' plane_size='600x800'
rotation='270' />
</crtc>
</startup>
</backend>
backend depth can be specified as '0', '1', '8', '16', '24', etc.
backend stencil can be specified as '0', '1', '8', '16', '24', etc.
backend raw_keyboards can be either '0' (default) or '1' --- enabling this
feature causes all libxkbcommon keymap handling to be disabled; keyboard
events will be delivered to clients with their evdev-generated keycodes
and no key mapping or modifier handling will be performed; this greatly
increases startup speed and is likely to match how keyboard-like devices
in real automotive settings work
crtc model can be 'disabled', 'classic', 'flexible', 'dualview', or 'stereo'
crtc mode can be 'preferred', 'current', or a specific
<width>x<height>@<refresh>
output mode can be 'inherit' or 'scale:<width>x<height>',
output position can be 'origin', 'rightof', 'below', or '<x>,<y>'
output target can be an output name to position this output relative to
output plane_position can be an '<x>,<y>' position relative to the origin
output plane_size should be '<W>x<H>' where <W> and <H> represent the
true, on-screen plane geometry
output rotation can be 0 (default), 90, 180, or 270 degrees
ias-plugin-framework
One of the unique features of the IAS compositor is the ability to invoke
customer supplied layout plug-ins. When a layout plug-in is loaded and
enabled, it intercepts the basic Weston compositor draw() function and
replaces it with whatever custom routines are provided by the plug-in.
This allows the customer to have complete control over how application
surfaces are presented on the screen. Example layout plug-ins are
provided, see below for more details.
In order to use the IAS plugin framework, it should be added as a loaded
module to the weston.ini config file. For example:
[core]
modules=ias-plugin-framework.so
Customer plugins should be specified in the ias.conf config file. For
example:
<plugin name='grid' lib='path_to_grid_plugin.so' />
<plugin name='list' lib='path_to_list_plugin.so' />
<input_plugin='touch' lib='path_to_touch_plugin.so' />
The IAS plugin framework may be used with any shell module, but some
IVI-specific functionality will only be available when using the IAS shell.
sample source code
grid_layout.c - An example layout plug-in. When invoked, it arranges
connected clients in a 4 x 4 grid on the screen. It is invoked
using a special key combination.
extension_sample.c - An example layout plug-in. When loaded, it creates a
new protocol extension that provides a custom API that clients can use.
In this case the API provides a rotate_cells() method and cell_selected
event. A test client for this extension is also included.
surface_gbc_control.c - An example layout plug-in. When invoked it uses a
shader to adjust gamma, brightness, and contrast via keyboard control.
input.c - An example layout plug-in. When invoked handles various type of
input; mouse, touch, etc.
sprite_example.c - An example layout plug-in. When invoked it arranges
connected clients in a grid using a sprite plane for the output.
ias-test-hmi.c - An example HMI client application. This simply
displays an info panel with text at the bottom of the screen. Client
applications are shown as windows on the display in the area above the
info panel.
This shows how to use the following:
1. Bind to the ias_shell and ias_hmi interfaces
2. Handle ias_shell configure events
3. Handle ias_hmi surface_info events
4. Use the ias_shell set_background() method to display a pattern
on the output background surface
5. Use the ias_shell set_zorder() method to position a surface at
the top of the zorder
6. Create a logo and center it on the screen
ias-test-shell.c - An example HMI client application. This simply
displays an info panel with text at the bottom of the screen. Client
applications are maximized to display in the area above the info panel.
This shows how to use the following:
1. Bind to the ias_shell and ias_hmi interfaces
2. Handle ias_shell configure events
3. Handle ias_hmi surface_info events
4. Use the ias_shell set_background() method to display a pattern
on the output background surface
5. Use the ias_shell set_zorder() method to position a surface at
the top of the zorder
6. Use the ias_hmi move_surface(), resize_surface() and
zorder_surface() methods to adjust client surfaces to fit with
the area designated for client surfaces
surfctrl.c - simple command line client that demonstrates how to use the
ias_hmi interface. This client shows how to use the following:
1. Bind to the ias_hmi interface
2. Handle surface_info events from the ias_hmi interface
3. Use the ias_hmi interface set_xy() to position a client surface
within an output's coordinate space.
4. Use the ias_hmi interface resize() method to change a client
surface size
5. Use the ias_hmi interface visible() method to make a client
surface hidden or visible
6. Use the ias_hmi interface alpha() method to change a client
surface alpha value
7. Use the ias_hmi interface zorder() method to change a client
surface zorder
layoutctrl.c - simple command line client that can activate/deactivate
layout plug-ins. This client shows how to use the following:
1. Bind to the ias_layout_manager interface
2. Handle manager_layout events from the ias_layout_manager interface
3. Handle manager_layout_switched events from the ias layout_manager
interface
4. Use the ias_layout_manager interface set_layout() method to
enable or disable a specific layout plugin for an output.
wrandr.c - simple command line client that controls outputs (position, mode,
color control, etc.). This demonstrates how to use do the following:
1. Bind to the ias_crtc and ias_output interfaces
2. Handle modelist events from the ias_crtc interface
3. Handle sprite events from the ias_crtc interface
4. Handle name events from the ias_output
5. Use the ias_crtc interface set_mode() method to set a mode
6. Use the ias_crtc interface set_gamma() to change the gamma value
7. Use the ias_crtc interface set_contrast() to change the contrast
8. Use the ias_crtc interface set_brightness() to change the brightness
9. Use the ias_crtc interface set_fb_transparency to set the
framebuffer alpha value
10. Use the ias_output interface scale_to() to scale the display
11. Use the ias_output interface set_xy() to position the output
within the global coordinate system
12. Use the ias_output interface disable() to disable an output
13. Use the ias_output interface enable() to enable an output
popup-test.c - a simple client to test the popup() method of the ias_shell
interface. It will display popup windows on the screen.
simple-hmi.c - Another example HMI client. This splits the display into an
info pane, a menu pane, and a main display area pane. A triangle is drawn
on the main display pane.
test-randr.c - A client that tests output control.