xref: /freebsd/sys/contrib/xen/io/cameraif.h (revision 13ec1e3155c7e9bf037b12af186351b7fa9b9450)
1 /******************************************************************************
2  * cameraif.h
3  *
4  * Unified camera device I/O interface for Xen guest OSes.
5  *
6  * Permission is hereby granted, free of charge, to any person obtaining a copy
7  * of this software and associated documentation files (the "Software"), to
8  * deal in the Software without restriction, including without limitation the
9  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10  * sell copies of the Software, and to permit persons to whom the Software is
11  * furnished to do so, subject to the following conditions:
12  *
13  * The above copyright notice and this permission notice shall be included in
14  * all copies or substantial portions of the Software.
15  *
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22  * DEALINGS IN THE SOFTWARE.
23  *
24  * Copyright (C) 2018-2019 EPAM Systems Inc.
25  *
26  * Author: Oleksandr Andrushchenko <oleksandr_andrushchenko@epam.com>
27  */
28 
29 #ifndef __XEN_PUBLIC_IO_CAMERAIF_H__
30 #define __XEN_PUBLIC_IO_CAMERAIF_H__
31 
32 #include "ring.h"
33 #include "../grant_table.h"
34 
35 /*
36  ******************************************************************************
37  *                           Protocol version
38  ******************************************************************************
39  */
40 #define XENCAMERA_PROTOCOL_VERSION     "1"
41 
42 /*
43  ******************************************************************************
44  *                  Feature and Parameter Negotiation
45  ******************************************************************************
46  *
47  * Front->back notifications: when enqueuing a new request, sending a
48  * notification can be made conditional on xencamera_req (i.e., the generic
49  * hold-off mechanism provided by the ring macros). Backends must set
50  * xencamera_req appropriately (e.g., using RING_FINAL_CHECK_FOR_REQUESTS()).
51  *
52  * Back->front notifications: when enqueuing a new response, sending a
53  * notification can be made conditional on xencamera_resp (i.e., the generic
54  * hold-off mechanism provided by the ring macros). Frontends must set
55  * xencamera_resp appropriately (e.g., using RING_FINAL_CHECK_FOR_RESPONSES()).
56  *
57  * The two halves of a para-virtual camera driver utilize nodes within
58  * XenStore to communicate capabilities and to negotiate operating parameters.
59  * This section enumerates these nodes which reside in the respective front and
60  * backend portions of XenStore, following the XenBus convention.
61  *
62  * All data in XenStore is stored as strings. Nodes specifying numeric
63  * values are encoded in decimal. Integer value ranges listed below are
64  * expressed as fixed sized integer types capable of storing the conversion
65  * of a properly formatted node string, without loss of information.
66  *
67  ******************************************************************************
68  *                        Example configuration
69  ******************************************************************************
70  *
71  * This is an example of backend and frontend configuration:
72  *
73  *--------------------------------- Backend -----------------------------------
74  *
75  * /local/domain/0/backend/vcamera/1/0/frontend-id = "1"
76  * /local/domain/0/backend/vcamera/1/0/frontend = "/local/domain/1/device/vcamera/0"
77  * /local/domain/0/backend/vcamera/1/0/state = "4"
78  * /local/domain/0/backend/vcamera/1/0/versions = "1,2"
79  *
80  *--------------------------------- Frontend ----------------------------------
81  *
82  * /local/domain/1/device/vcamera/0/backend-id = "0"
83  * /local/domain/1/device/vcamera/0/backend = "/local/domain/0/backend/vcamera/1"
84  * /local/domain/1/device/vcamera/0/state = "4"
85  * /local/domain/1/device/vcamera/0/version = "1"
86  * /local/domain/1/device/vcamera/0/be-alloc = "1"
87  *
88  *---------------------------- Device 0 configuration -------------------------
89  *
90  * /local/domain/1/device/vcamera/0/max-buffers = "3"
91  * /local/domain/1/device/vcamera/0/controls = "contrast,hue"
92  * /local/domain/1/device/vcamera/0/formats/YUYV/640x480/frame-rates = "30/1,15/1"
93  * /local/domain/1/device/vcamera/0/formats/YUYV/1920x1080/frame-rates = "15/2"
94  * /local/domain/1/device/vcamera/0/formats/BGRA/640x480/frame-rates = "15/1,15/2"
95  * /local/domain/1/device/vcamera/0/formats/BGRA/1200x720/frame-rates = "15/2"
96  * /local/domain/1/device/vcamera/0/unique-id = "0"
97  * /local/domain/1/device/vcamera/0/req-ring-ref = "2832"
98  * /local/domain/1/device/vcamera/0/req-event-channel = "15"
99  * /local/domain/1/device/vcamera/0/evt-ring-ref = "387"
100  * /local/domain/1/device/vcamera/0/evt-event-channel = "16"
101  *
102  *---------------------------- Device 1 configuration -------------------------
103  *
104  * /local/domain/1/device/vcamera/1/max-buffers = "8"
105  * /local/domain/1/device/vcamera/1/controls = "brightness,saturation,hue"
106  * /local/domain/1/device/vcamera/1/formats/YUYV/640x480/frame-rates = "30/1,15/2"
107  * /local/domain/1/device/vcamera/1/formats/YUYV/1920x1080/frame-rates = "15/2"
108  * /local/domain/1/device/vcamera/1/unique-id = "1"
109  * /local/domain/1/device/vcamera/1/req-ring-ref = "2833"
110  * /local/domain/1/device/vcamera/1/req-event-channel = "17"
111  * /local/domain/1/device/vcamera/1/evt-ring-ref = "388"
112  * /local/domain/1/device/vcamera/1/evt-event-channel = "18"
113  *
114  ******************************************************************************
115  *                            Backend XenBus Nodes
116  ******************************************************************************
117  *
118  *----------------------------- Protocol version ------------------------------
119  *
120  * versions
121  *      Values:         <string>
122  *
123  *      List of XENCAMERA_LIST_SEPARATOR separated protocol versions supported
124  *      by the backend. For example "1,2,3".
125  *
126  ******************************************************************************
127  *                            Frontend XenBus Nodes
128  ******************************************************************************
129  *
130  *-------------------------------- Addressing ---------------------------------
131  *
132  * dom-id
133  *      Values:         <uint16_t>
134  *
135  *      Domain identifier.
136  *
137  * dev-id
138  *      Values:         <uint16_t>
139  *
140  *      Device identifier.
141  *
142  *      /local/domain/<dom-id>/device/vcamera/<dev-id>/...
143  *
144  *----------------------------- Protocol version ------------------------------
145  *
146  * version
147  *      Values:         <string>
148  *
149  *      Protocol version, chosen among the ones supported by the backend.
150  *
151  *------------------------- Backend buffer allocation -------------------------
152  *
153  * be-alloc
154  *      Values:         "0", "1"
155  *
156  *      If value is set to "1", then backend will be the buffer
157  *      provider/allocator for this domain during XENCAMERA_OP_BUF_CREATE
158  *      operation.
159  *      If value is not "1" or omitted frontend must allocate buffers itself.
160  *
161  *------------------------------- Camera settings -----------------------------
162  *
163  * unique-id
164  *      Values:         <string>
165  *
166  *      After device instance initialization each camera is assigned a
167  *      unique ID, so it can be identified by the backend by this ID.
168  *      This can be UUID or such.
169  *
170  * max-buffers
171  *      Values:         <uint8_t>
172  *
173  *      Maximum number of camera buffers this frontend may use.
174  *
175  * controls
176  *      Values:         <list of string>
177  *
178  *      List of supported camera controls separated by XENCAMERA_LIST_SEPARATOR.
179  *      Camera controls are expressed as a list of string values w/o any
180  *      ordering requirement.
181  *
182  * formats
183  *      Values:         <format, char[7]>
184  *
185  *      Formats are organized as a set of directories one per each
186  *      supported pixel format. The name of the directory is the
187  *      corresponding FOURCC string label. The next level of
188  *      the directory under <formats> represents supported resolutions.
189  *      If the format represents a big-endian variant of a little
190  *      endian format, then the "-BE" suffix must be added. E.g. 'AR15' vs
191  *      'AR15-BE'.
192  *      If FOURCC string label has spaces then those are only allowed to
193  *      be at the end of the label and must be trimmed, for example
194  *      'Y16' and 'Y16-BE' will be trimmed.
195  *
196  * resolution
197  *      Values:         <width, uint32_t>x<height, uint32_t>
198  *
199  *      Resolutions are organized as a set of directories one per each
200  *      supported resolution under corresponding <formats> directory.
201  *      The name of the directory is the supported width and height
202  *      of the camera resolution in pixels.
203  *
204  * frame-rates
205  *      Values:         <numerator, uint32_t>/<denominator, uint32_t>
206  *
207  *      List of XENCAMERA_FRAME_RATE_SEPARATOR separated supported frame rates
208  *      of the camera expressed as numerator and denominator of the
209  *      corresponding frame rate.
210  *
211  *------------------- Camera Request Transport Parameters ---------------------
212  *
213  * This communication path is used to deliver requests from frontend to backend
214  * and get the corresponding responses from backend to frontend,
215  * set up per virtual camera device.
216  *
217  * req-event-channel
218  *      Values:         <uint32_t>
219  *
220  *      The identifier of the Xen camera's control event channel
221  *      used to signal activity in the ring buffer.
222  *
223  * req-ring-ref
224  *      Values:         <uint32_t>
225  *
226  *      The Xen grant reference granting permission for the backend to map
227  *      a sole page of camera's control ring buffer.
228  *
229  *-------------------- Camera Event Transport Parameters ----------------------
230  *
231  * This communication path is used to deliver asynchronous events from backend
232  * to frontend, set up per virtual camera device.
233  *
234  * evt-event-channel
235  *      Values:         <uint32_t>
236  *
237  *      The identifier of the Xen camera's event channel
238  *      used to signal activity in the ring buffer.
239  *
240  * evt-ring-ref
241  *      Values:         <uint32_t>
242  *
243  *      The Xen grant reference granting permission for the backend to map
244  *      a sole page of camera's event ring buffer.
245  */
246 
247 /*
248  ******************************************************************************
249  *                               STATE DIAGRAMS
250  ******************************************************************************
251  *
252  * Tool stack creates front and back state nodes with initial state
253  * XenbusStateInitialising.
254  * Tool stack creates and sets up frontend camera configuration
255  * nodes per domain.
256  *
257  *-------------------------------- Normal flow --------------------------------
258  *
259  * Front                                Back
260  * =================================    =====================================
261  * XenbusStateInitialising              XenbusStateInitialising
262  *                                       o Query backend device identification
263  *                                         data.
264  *                                       o Open and validate backend device.
265  *                                                |
266  *                                                |
267  *                                                V
268  *                                      XenbusStateInitWait
269  *
270  * o Query frontend configuration
271  * o Allocate and initialize
272  *   event channels per configured
273  *   camera.
274  * o Publish transport parameters
275  *   that will be in effect during
276  *   this connection.
277  *              |
278  *              |
279  *              V
280  * XenbusStateInitialised
281  *
282  *                                       o Query frontend transport parameters.
283  *                                       o Connect to the event channels.
284  *                                                |
285  *                                                |
286  *                                                V
287  *                                      XenbusStateConnected
288  *
289  *  o Create and initialize OS
290  *    virtual camera as per
291  *    configuration.
292  *              |
293  *              |
294  *              V
295  * XenbusStateConnected
296  *
297  *                                      XenbusStateUnknown
298  *                                      XenbusStateClosed
299  *                                      XenbusStateClosing
300  * o Remove virtual camera device
301  * o Remove event channels
302  *              |
303  *              |
304  *              V
305  * XenbusStateClosed
306  *
307  *------------------------------- Recovery flow -------------------------------
308  *
309  * In case of frontend unrecoverable errors backend handles that as
310  * if frontend goes into the XenbusStateClosed state.
311  *
312  * In case of backend unrecoverable errors frontend tries removing
313  * the virtualized device. If this is possible at the moment of error,
314  * then frontend goes into the XenbusStateInitialising state and is ready for
315  * new connection with backend. If the virtualized device is still in use and
316  * cannot be removed, then frontend goes into the XenbusStateReconfiguring state
317  * until either the virtualized device is removed or backend initiates a new
318  * connection. On the virtualized device removal frontend goes into the
319  * XenbusStateInitialising state.
320  *
321  * Note on XenbusStateReconfiguring state of the frontend: if backend has
322  * unrecoverable errors then frontend cannot send requests to the backend
323  * and thus cannot provide functionality of the virtualized device anymore.
324  * After backend is back to normal the virtualized device may still hold some
325  * state: configuration in use, allocated buffers, client application state etc.
326  * In most cases, this will require frontend to implement complex recovery
327  * reconnect logic. Instead, by going into XenbusStateReconfiguring state,
328  * frontend will make sure no new clients of the virtualized device are
329  * accepted, allow existing client(s) to exit gracefully by signaling error
330  * state etc.
331  * Once all the clients are gone frontend can reinitialize the virtualized
332  * device and get into XenbusStateInitialising state again signaling the
333  * backend that a new connection can be made.
334  *
335  * There are multiple conditions possible under which frontend will go from
336  * XenbusStateReconfiguring into XenbusStateInitialising, some of them are OS
337  * specific. For example:
338  * 1. The underlying OS framework may provide callbacks to signal that the last
339  *    client of the virtualized device has gone and the device can be removed
340  * 2. Frontend can schedule a deferred work (timer/tasklet/workqueue)
341  *    to periodically check if this is the right time to re-try removal of
342  *    the virtualized device.
343  * 3. By any other means.
344  *
345  ******************************************************************************
346  *                             REQUEST CODES
347  ******************************************************************************
348  */
349 #define XENCAMERA_OP_CONFIG_SET        0x00
350 #define XENCAMERA_OP_CONFIG_GET        0x01
351 #define XENCAMERA_OP_CONFIG_VALIDATE   0x02
352 #define XENCAMERA_OP_FRAME_RATE_SET    0x03
353 #define XENCAMERA_OP_BUF_GET_LAYOUT    0x04
354 #define XENCAMERA_OP_BUF_REQUEST       0x05
355 #define XENCAMERA_OP_BUF_CREATE        0x06
356 #define XENCAMERA_OP_BUF_DESTROY       0x07
357 #define XENCAMERA_OP_BUF_QUEUE         0x08
358 #define XENCAMERA_OP_BUF_DEQUEUE       0x09
359 #define XENCAMERA_OP_CTRL_ENUM         0x0a
360 #define XENCAMERA_OP_CTRL_SET          0x0b
361 #define XENCAMERA_OP_CTRL_GET          0x0c
362 #define XENCAMERA_OP_STREAM_START      0x0d
363 #define XENCAMERA_OP_STREAM_STOP       0x0e
364 
365 #define XENCAMERA_CTRL_BRIGHTNESS      0
366 #define XENCAMERA_CTRL_CONTRAST        1
367 #define XENCAMERA_CTRL_SATURATION      2
368 #define XENCAMERA_CTRL_HUE             3
369 
370 /* Number of supported controls. */
371 #define XENCAMERA_MAX_CTRL             4
372 
373 /* Control is read-only. */
374 #define XENCAMERA_CTRL_FLG_RO          (1 << 0)
375 /* Control is write-only. */
376 #define XENCAMERA_CTRL_FLG_WO          (1 << 1)
377 /* Control's value is volatile. */
378 #define XENCAMERA_CTRL_FLG_VOLATILE    (1 << 2)
379 
380 /* Supported color spaces. */
381 #define XENCAMERA_COLORSPACE_DEFAULT   0
382 #define XENCAMERA_COLORSPACE_SMPTE170M 1
383 #define XENCAMERA_COLORSPACE_REC709    2
384 #define XENCAMERA_COLORSPACE_SRGB      3
385 #define XENCAMERA_COLORSPACE_OPRGB     4
386 #define XENCAMERA_COLORSPACE_BT2020    5
387 #define XENCAMERA_COLORSPACE_DCI_P3    6
388 
389 /* Color space transfer function. */
390 #define XENCAMERA_XFER_FUNC_DEFAULT    0
391 #define XENCAMERA_XFER_FUNC_709        1
392 #define XENCAMERA_XFER_FUNC_SRGB       2
393 #define XENCAMERA_XFER_FUNC_OPRGB      3
394 #define XENCAMERA_XFER_FUNC_NONE       4
395 #define XENCAMERA_XFER_FUNC_DCI_P3     5
396 #define XENCAMERA_XFER_FUNC_SMPTE2084  6
397 
398 /* Color space Y’CbCr encoding. */
399 #define XENCAMERA_YCBCR_ENC_IGNORE           0
400 #define XENCAMERA_YCBCR_ENC_601              1
401 #define XENCAMERA_YCBCR_ENC_709              2
402 #define XENCAMERA_YCBCR_ENC_XV601            3
403 #define XENCAMERA_YCBCR_ENC_XV709            4
404 #define XENCAMERA_YCBCR_ENC_BT2020           5
405 #define XENCAMERA_YCBCR_ENC_BT2020_CONST_LUM 6
406 
407 /* Quantization range. */
408 #define XENCAMERA_QUANTIZATION_DEFAULT       0
409 #define XENCAMERA_QUANTIZATION_FULL_RANGE    1
410 #define XENCAMERA_QUANTIZATION_LIM_RANGE     2
411 
412 /*
413  ******************************************************************************
414  *                                 EVENT CODES
415  ******************************************************************************
416  */
417 #define XENCAMERA_EVT_FRAME_AVAIL      0x00
418 #define XENCAMERA_EVT_CTRL_CHANGE      0x01
419 
420 /*
421  ******************************************************************************
422  *               XENSTORE FIELD AND PATH NAME STRINGS, HELPERS
423  ******************************************************************************
424  */
425 #define XENCAMERA_DRIVER_NAME          "vcamera"
426 
427 #define XENCAMERA_LIST_SEPARATOR       ","
428 #define XENCAMERA_RESOLUTION_SEPARATOR "x"
429 #define XENCAMERA_FRACTION_SEPARATOR   "/"
430 
431 #define XENCAMERA_FIELD_BE_VERSIONS    "versions"
432 #define XENCAMERA_FIELD_FE_VERSION     "version"
433 #define XENCAMERA_FIELD_REQ_RING_REF   "req-ring-ref"
434 #define XENCAMERA_FIELD_REQ_CHANNEL    "req-event-channel"
435 #define XENCAMERA_FIELD_EVT_RING_REF   "evt-ring-ref"
436 #define XENCAMERA_FIELD_EVT_CHANNEL    "evt-event-channel"
437 #define XENCAMERA_FIELD_MAX_BUFFERS    "max-buffers"
438 #define XENCAMERA_FIELD_CONTROLS       "controls"
439 #define XENCAMERA_FIELD_FORMATS        "formats"
440 #define XENCAMERA_FIELD_FRAME_RATES    "frame-rates"
441 #define XENCAMERA_FIELD_BE_ALLOC       "be-alloc"
442 #define XENCAMERA_FIELD_UNIQUE_ID      "unique-id"
443 
444 #define XENCAMERA_CTRL_BRIGHTNESS_STR  "brightness"
445 #define XENCAMERA_CTRL_CONTRAST_STR    "contrast"
446 #define XENCAMERA_CTRL_SATURATION_STR  "saturation"
447 #define XENCAMERA_CTRL_HUE_STR         "hue"
448 
449 #define XENCAMERA_FOURCC_BIGENDIAN_STR "-BE"
450 
451 /* Maximum number of buffer planes supported. */
452 #define XENCAMERA_MAX_PLANE            4
453 
454 /*
455  ******************************************************************************
456  *                          STATUS RETURN CODES
457  ******************************************************************************
458  *
459  * Status return code is zero on success and -XEN_EXX on failure.
460  *
461  ******************************************************************************
462  *                              Assumptions
463  ******************************************************************************
464  *
465  * - usage of grant reference 0 as invalid grant reference:
466  *   grant reference 0 is valid, but never exposed to a PV driver,
467  *   because of the fact it is already in use/reserved by the PV console.
468  * - all references in this document to page sizes must be treated
469  *   as pages of size XEN_PAGE_SIZE unless otherwise noted.
470  * - all FOURCC mappings used for configuration and messaging are
471  *   Linux V4L2 ones: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/include/uapi/linux/videodev2.h
472  *   with the following exceptions:
473  *     - characters are allowed in [0x20; 0x7f] range
474  *     - when used for XenStore configuration entries the following
475  *       are not allowed:
476  *       - '/', '\', ' ' (space), '<', '>', ':', '"', '|', '?', '*'
477  *       - if trailing spaces are part of the FOURCC code then those must be
478  *         trimmed
479  *
480  *
481  ******************************************************************************
482  *       Description of the protocol between frontend and backend driver
483  ******************************************************************************
484  *
485  * The two halves of a Para-virtual camera driver communicate with
486  * each other using shared pages and event channels.
487  * Shared page contains a ring with request/response packets.
488  *
489  * All reserved fields in the structures below must be 0.
490  *
491  * For all request/response/event packets:
492  *   - frame rate parameter is represented as a pair of 4 octet long
493  *     numerator and denominator:
494  *       - frame_rate_numer - uint32_t, numerator of the frame rate
495  *       - frame_rate_denom - uint32_t, denominator of the frame rate
496  *     The corresponding frame rate (Hz) is calculated as:
497  *       frame_rate = frame_rate_numer / frame_rate_denom
498  *   - buffer index is a zero based index of the buffer. Must be less than
499  *     the value of XENCAMERA_OP_CONFIG_SET.num_bufs response:
500  *       - index - uint8_t, index of the buffer.
501  *
502  *
503  *---------------------------------- Requests ---------------------------------
504  *
505  * All request packets have the same length (64 octets).
506  * All request packets have common header:
507  *         0                1                 2               3        octet
508  * +----------------+----------------+----------------+----------------+
509  * |               id                |    operation   |   reserved     | 4
510  * +----------------+----------------+----------------+----------------+
511  * |                             reserved                              | 8
512  * +----------------+----------------+----------------+----------------+
513  *   id - uint16_t, private guest value, echoed in response.
514  *   operation - uint8_t, operation code, XENCAMERA_OP_XXX.
515  *
516  *
517  * Request to set/validate the configuration - request to set the
518  * configuration/mode of the camera (XENCAMERA_OP_CONFIG_SET) or to
519  * check if the configuration is valid and can be used
520  * (XENCAMERA_OP_CONFIG_VALIDATE):
521  *         0                1                 2               3        octet
522  * +----------------+----------------+----------------+----------------+
523  * |               id                | _OP_CONFIG_XXX |   reserved     | 4
524  * +----------------+----------------+----------------+----------------+
525  * |                             reserved                              | 8
526  * +----------------+----------------+----------------+----------------+
527  * |                            pixel format                           | 12
528  * +----------------+----------------+----------------+----------------+
529  * |                               width                               | 16
530  * +----------------+----------------+----------------+----------------+
531  * |                               height                              | 20
532  * +----------------+----------------+----------------+----------------+
533  * |                             reserved                              | 24
534  * +----------------+----------------+----------------+----------------+
535  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
536  * +----------------+----------------+----------------+----------------+
537  * |                             reserved                              | 64
538  * +----------------+----------------+----------------+----------------+
539  *
540  * pixel_format - uint32_t, pixel format to be used, FOURCC code.
541  * width - uint32_t, width in pixels.
542  * height - uint32_t, height in pixels.
543  *
544  * See response format for this request.
545  *
546  * Notes:
547  *  - the only difference between XENCAMERA_OP_CONFIG_VALIDATE and
548  *    XENCAMERA_OP_CONFIG_SET is that the former doesn't actually change
549  *    camera configuration, but queries if the configuration is valid.
550  *    This can be used while stream is active and/or buffers allocated.
551  *  - frontend must check the corresponding response in order to see
552  *    if the values reported back by the backend do match the desired ones
553  *    and can be accepted.
554  *  - frontend may send multiple XENCAMERA_OP_CONFIG_SET requests before
555  *    sending XENCAMERA_OP_STREAM_START request to update or tune the
556  *    final stream configuration.
557  *  - configuration cannot be changed during active streaming, e.g.
558  *    after XENCAMERA_OP_STREAM_START and before XENCAMERA_OP_STREAM_STOP
559  *    requests.
560  */
561 struct xencamera_config_req {
562     uint32_t pixel_format;
563     uint32_t width;
564     uint32_t height;
565 };
566 
567 /*
568  * Request current configuration of the camera:
569  *         0                1                 2               3        octet
570  * +----------------+----------------+----------------+----------------+
571  * |               id                | _OP_CONFIG_GET |   reserved     | 4
572  * +----------------+----------------+----------------+----------------+
573  * |                             reserved                              | 8
574  * +----------------+----------------+----------------+----------------+
575  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
576  * +----------------+----------------+----------------+----------------+
577  * |                             reserved                              | 64
578  * +----------------+----------------+----------------+----------------+
579  *
580  * See response format for this request.
581  *
582  *
583  * Request to set the frame rate of the stream:
584  *         0                1                 2               3        octet
585  * +----------------+----------------+----------------+----------------+
586  * |               id                | _FRAME_RATE_SET|   reserved     | 4
587  * +----------------+----------------+----------------+----------------+
588  * |                             reserved                              | 8
589  * +----------------+----------------+----------------+----------------+
590  * |                          frame_rate_numer                         | 12
591  * +----------------+----------------+----------------+----------------+
592  * |                          frame_rate_denom                         | 16
593  * +----------------+----------------+----------------+----------------+
594  * |                             reserved                              | 20
595  * +----------------+----------------+----------------+----------------+
596  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
597  * +----------------+----------------+----------------+----------------+
598  * |                             reserved                              | 64
599  * +----------------+----------------+----------------+----------------+
600  *
601  * frame_rate_numer - uint32_t, numerator of the frame rate.
602  * frame_rate_denom - uint32_t, denominator of the frame rate.
603  *
604  * Notes:
605  *  - to query the current (actual) frame rate use XENCAMERA_OP_CONFIG_GET
606  *    request.
607  *  - this request can be used with camera buffers allocated, but stream
608  *    stopped, e.g. frontend is allowed to stop the stream with
609  *    XENCAMERA_OP_STREAM_STOP, hold the buffers allocated (e.g. keep the
610  *    configuration set with XENCAMERA_OP_CONFIG_SET), change the
611  *    frame rate of the stream and (re)start the stream again with
612  *    XENCAMERA_OP_STREAM_START.
613  *  - frame rate cannot be changed during active streaming, e.g.
614  *    after XENCAMERA_OP_STREAM_START and before XENCAMERA_OP_STREAM_STOP
615  *    commands.
616  */
617 struct xencamera_frame_rate_req {
618     uint32_t frame_rate_numer;
619     uint32_t frame_rate_denom;
620 };
621 
622 /*
623  * Request camera buffer's layout:
624  *         0                1                 2               3        octet
625  * +----------------+----------------+----------------+----------------+
626  * |               id                | _BUF_GET_LAYOUT|   reserved     | 4
627  * +----------------+----------------+----------------+----------------+
628  * |                             reserved                              | 8
629  * +----------------+----------------+----------------+----------------+
630  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
631  * +----------------+----------------+----------------+----------------+
632  * |                             reserved                              | 64
633  * +----------------+----------------+----------------+----------------+
634  *
635  * See response format for this request.
636  *
637  *
638  * Request number of buffers to be used:
639  *         0                1                 2               3        octet
640  * +----------------+----------------+----------------+----------------+
641  * |               id                | _OP_BUF_REQUEST|   reserved     | 4
642  * +----------------+----------------+----------------+----------------+
643  * |                             reserved                              | 8
644  * +----------------+----------------+----------------+----------------+
645  * |    num_bufs    |                     reserved                     | 12
646  * +----------------+----------------+----------------+----------------+
647  * |                             reserved                              | 16
648  * +----------------+----------------+----------------+----------------+
649  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
650  * +----------------+----------------+----------------+----------------+
651  * |                             reserved                              | 64
652  * +----------------+----------------+----------------+----------------+
653  *
654  * num_bufs - uint8_t, desired number of buffers to be used.
655  *
656  * If num_bufs is not zero then the backend validates the requested number of
657  * buffers and responds with the number of buffers allowed for this frontend.
658  * Frontend is responsible for checking the corresponding response in order to
659  * see if the values reported back by the backend do match the desired ones
660  * and can be accepted.
661  * Frontend is allowed to send multiple XENCAMERA_OP_BUF_REQUEST requests
662  * before sending XENCAMERA_OP_STREAM_START request to update or tune the
663  * final configuration.
664  * Frontend is not allowed to change the camera configuration after this call
665  * with a non-zero value of num_bufs. If camera reconfiguration is required
666  * then this request must be sent with num_bufs set to zero and any created
667  * buffers must be destroyed first.
668  * Frontend is not allowed to change the number of buffers after the
669  * streaming has started.
670  *
671  * If num_bufs is 0 and streaming has not started yet, then the backend will
672  * free all previously allocated buffers (if any).
673  * Trying to call this if streaming is in progress will result in an error.
674  *
675  * If camera reconfiguration is required then the streaming must be stopped
676  * and this request must be sent with num_bufs set to zero and any
677  * created buffers must be destroyed.
678  *
679  * Please note, that the number of buffers in this request must not exceed
680  * the value configured in XenStore.max-buffers.
681  *
682  * See response format for this request.
683  */
684 struct xencamera_buf_request {
685     uint8_t num_bufs;
686 };
687 
688 /*
689  * Request camera buffer creation:
690  *         0                1                 2               3        octet
691  * +----------------+----------------+----------------+----------------+
692  * |               id                | _OP_BUF_CREATE |   reserved     | 4
693  * +----------------+----------------+----------------+----------------+
694  * |                             reserved                              | 8
695  * +----------------+----------------+----------------+----------------+
696  * |      index     |                     reserved                     | 12
697  * +----------------+----------------+----------------+----------------+
698  * |                           plane_offset[0]                         | 16
699  * +----------------+----------------+----------------+----------------+
700  * |                           plane_offset[1]                         | 20
701  * +----------------+----------------+----------------+----------------+
702  * |                           plane_offset[2]                         | 24
703  * +----------------+----------------+----------------+----------------+
704  * |                           plane_offset[3]                         | 28
705  * +----------------+----------------+----------------+----------------+
706  * |                           gref_directory                          | 32
707  * +----------------+----------------+----------------+----------------+
708  * |                             reserved                              | 36
709  * +----------------+----------------+----------------+----------------+
710  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
711  * +----------------+----------------+----------------+----------------+
712  * |                             reserved                              | 64
713  * +----------------+----------------+----------------+----------------+
714  *
715  * An attempt to create multiple buffers with the same index is an error.
716  * index can be re-used after destroying the corresponding camera buffer.
717  *
718  * index - uint8_t, index of the buffer to be created in the range
719  *   from 0 to the num_bufs field returned in response for
720  *   XENCAMERA_OP_BUF_REQUEST request
721  * plane_offset - array of uint32_t, offset of the corresponding plane
722  *   in octets from the buffer start. Number of offsets returned is
723  *   equal to the value returned in XENCAMERA_OP_BUF_GET_LAYOUT.num_planes.
724  * gref_directory - grant_ref_t, a reference to the first shared page
725  *   describing shared buffer references. The size of the buffer is equal to
726  *   XENCAMERA_OP_BUF_GET_LAYOUT.size response. At least one page exists. If
727  *   shared buffer size exceeds what can be addressed by this single page,
728  *   then reference to the next shared page must be supplied (see
729  *   gref_dir_next_page below).
730  *
731  * If XENCAMERA_FIELD_BE_ALLOC configuration entry is set, then backend will
732  * allocate the buffer with the parameters provided in this request and page
733  * directory is handled as follows:
734  *   Frontend on request:
735  *     - allocates pages for the directory (gref_directory,
736  *       gref_dir_next_page(s)
737  *     - grants permissions for the pages of the directory to the backend
738  *     - sets gref_dir_next_page fields
739  *   Backend on response:
740  *     - grants permissions for the pages of the buffer allocated to
741  *       the frontend
742  *     - fills in page directory with grant references
743  *       (gref[] in struct xencamera_page_directory)
744  */
745 struct xencamera_buf_create_req {
746     uint8_t index;
747     uint8_t reserved[3];
748     uint32_t plane_offset[XENCAMERA_MAX_PLANE];
749     grant_ref_t gref_directory;
750 };
751 
752 /*
753  * Shared page for XENCAMERA_OP_BUF_CREATE buffer descriptor (gref_directory in
754  * the request) employs a list of pages, describing all pages of the shared
755  * data buffer:
756  *         0                1                 2               3        octet
757  * +----------------+----------------+----------------+----------------+
758  * |                        gref_dir_next_page                         | 4
759  * +----------------+----------------+----------------+----------------+
760  * |                              gref[0]                              | 8
761  * +----------------+----------------+----------------+----------------+
762  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
763  * +----------------+----------------+----------------+----------------+
764  * |                              gref[i]                              | i*4+8
765  * +----------------+----------------+----------------+----------------+
766  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
767  * +----------------+----------------+----------------+----------------+
768  * |                             gref[N - 1]                           | N*4+8
769  * +----------------+----------------+----------------+----------------+
770  *
771  * gref_dir_next_page - grant_ref_t, reference to the next page describing
772  *   page directory. Must be 0 if there are no more pages in the list.
773  * gref[i] - grant_ref_t, reference to a shared page of the buffer
774  *   allocated at XENCAMERA_OP_BUF_CREATE.
775  *
776  * Number of grant_ref_t entries in the whole page directory is not
777  * passed, but instead can be calculated as:
778  *   num_grefs_total = (XENCAMERA_OP_BUF_REQUEST.size + XEN_PAGE_SIZE - 1) /
779  *       XEN_PAGE_SIZE
780  */
781 struct xencamera_page_directory {
782     grant_ref_t gref_dir_next_page;
783     grant_ref_t gref[1]; /* Variable length */
784 };
785 
786 /*
787  * Request buffer destruction - destroy a previously allocated camera buffer:
788  *         0                1                 2               3        octet
789  * +----------------+----------------+----------------+----------------+
790  * |               id                | _OP_BUF_DESTROY|   reserved     | 4
791  * +----------------+----------------+----------------+----------------+
792  * |                             reserved                              | 8
793  * +----------------+----------------+----------------+----------------+
794  * |      index     |                     reserved                     | 12
795  * +----------------+----------------+----------------+----------------+
796  * |                             reserved                              | 16
797  * +----------------+----------------+----------------+----------------+
798  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
799  * +----------------+----------------+----------------+----------------+
800  * |                             reserved                              | 64
801  * +----------------+----------------+----------------+----------------+
802  *
803  * index - uint8_t, index of the buffer to be destroyed.
804  *
805  *
806  * Request queueing of the buffer for backend use:
807  *         0                1                 2               3        octet
808  * +----------------+----------------+----------------+----------------+
809  * |               id                | _OP_BUF_QUEUE  |   reserved     | 4
810  * +----------------+----------------+----------------+----------------+
811  * |                             reserved                              | 8
812  * +----------------+----------------+----------------+----------------+
813  * |      index     |                     reserved                     | 12
814  * +----------------+----------------+----------------+----------------+
815  * |                             reserved                              | 16
816  * +----------------+----------------+----------------+----------------+
817  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
818  * +----------------+----------------+----------------+----------------+
819  * |                             reserved                              | 64
820  * +----------------+----------------+----------------+----------------+
821  *
822  * Notes:
823  *  - frontends must not access the buffer content after this request until
824  *    response to XENCAMERA_OP_BUF_DEQUEUE has been received.
825  *  - buffers must be queued to the backend before destroying them with
826  *    XENCAMERA_OP_BUF_DESTROY.
827  *
828  * index - uint8_t, index of the buffer to be queued.
829  *
830  *
831  * Request dequeueing of the buffer for frontend use:
832  *         0                1                 2               3        octet
833  * +----------------+----------------+----------------+----------------+
834  * |               id                |_OP_BUF_DEQUEUE |   reserved     | 4
835  * +----------------+----------------+----------------+----------------+
836  * |                             reserved                              | 8
837  * +----------------+----------------+----------------+----------------+
838  * |      index     |                     reserved                     | 12
839  * +----------------+----------------+----------------+----------------+
840  * |                             reserved                              | 16
841  * +----------------+----------------+----------------+----------------+
842  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
843  * +----------------+----------------+----------------+----------------+
844  * |                             reserved                              | 64
845  * +----------------+----------------+----------------+----------------+
846  *
847  * Notes:
848  *  - frontend is allowed to access the buffer content after the corresponding
849  *    response to this request.
850  *
851  * index - uint8_t, index of the buffer to be queued.
852  *
853  *
854  * Request camera control details:
855  *         0                1                 2               3        octet
856  * +----------------+----------------+----------------+----------------+
857  * |               id                | _OP_CTRL_ENUM  |   reserved     | 4
858  * +----------------+----------------+----------------+----------------+
859  * |      index     |                     reserved                     | 8
860  * +----------------+----------------+----------------+----------------+
861  * |                             reserved                              | 12
862  * +----------------+----------------+----------------+----------------+
863  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
864  * +----------------+----------------+----------------+----------------+
865  * |                             reserved                              | 64
866  * +----------------+----------------+----------------+----------------+
867  *
868  * See response format for this request.
869  *
870  * index - uint8_t, index of the control to be queried.
871  */
872 struct xencamera_index {
873     uint8_t index;
874 };
875 
876 /*
877  * Request camera control change:
878  *         0                1                 2               3        octet
879  * +----------------+----------------+----------------+----------------+
880  * |               id                |  _OP_SET_CTRL  |   reserved     | 4
881  * +----------------+----------------+----------------+----------------+
882  * |       type     |                     reserved                     | 8
883  * +----------------+----------------+----------------+----------------+
884  * |                             reserved                              | 12
885  * +----------------+----------------+----------------+----------------+
886  * |                             reserved                              | 16
887  * +----------------+----------------+----------------+----------------+
888  * |                          value low 32-bit                         | 20
889  * +----------------+----------------+----------------+----------------+
890  * |                          value high 32-bit                        | 24
891  * +----------------+----------------+----------------+----------------+
892  * |                             reserved                              | 28
893  * +----------------+----------------+----------------+----------------+
894  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
895  * +----------------+----------------+----------------+----------------+
896  * |                             reserved                              | 64
897  * +----------------+----------------+----------------+----------------+
898  *
899  * type - uint8_t, type of the control, one of the XENCAMERA_CTRL_XXX.
900  * value - int64_t, new value of the control.
901  */
902 struct xencamera_ctrl_value {
903     uint8_t type;
904     uint8_t reserved[7];
905     int64_t value;
906 };
907 
908 /*
909  * Request camera control state:
910  *         0                1                 2               3        octet
911  * +----------------+----------------+----------------+----------------+
912  * |               id                |  _OP_GET_CTRL  |   reserved     | 4
913  * +----------------+----------------+----------------+----------------+
914  * |       type     |                     reserved                     | 8
915  * +----------------+----------------+----------------+----------------+
916  * |                             reserved                              | 12
917  * +----------------+----------------+----------------+----------------+
918  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
919  * +----------------+----------------+----------------+----------------+
920  * |                             reserved                              | 64
921  * +----------------+----------------+----------------+----------------+
922  *
923  * See response format for this request.
924  *
925  * type - uint8_t, type of the control, one of the XENCAMERA_CTRL_XXX.
926  */
927 struct xencamera_get_ctrl_req {
928     uint8_t type;
929 };
930 
931 /*
932  * Request camera capture stream start:
933  *         0                1                 2               3        octet
934  * +----------------+----------------+----------------+----------------+
935  * |               id                |_OP_STREAM_START|   reserved     | 4
936  * +----------------+----------------+----------------+----------------+
937  * |                             reserved                              | 8
938  * +----------------+----------------+----------------+----------------+
939  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
940  * +----------------+----------------+----------------+----------------+
941  * |                             reserved                              | 64
942  * +----------------+----------------+----------------+----------------+
943  *
944  *
945  * Request camera capture stream stop:
946  *         0                1                 2               3        octet
947  * +----------------+----------------+----------------+----------------+
948  * |               id                |_OP_STREAM_STOP |   reserved     | 4
949  * +----------------+----------------+----------------+----------------+
950  * |                             reserved                              | 8
951  * +----------------+----------------+----------------+----------------+
952  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
953  * +----------------+----------------+----------------+----------------+
954  * |                             reserved                              | 64
955  * +----------------+----------------+----------------+----------------+
956  *
957  *
958  *---------------------------------- Responses --------------------------------
959  *
960  * All response packets have the same length (64 octets).
961  *
962  * All response packets have common header:
963  *         0                1                 2               3        octet
964  * +----------------+----------------+----------------+----------------+
965  * |               id                |    operation   |    reserved    | 4
966  * +----------------+----------------+----------------+----------------+
967  * |                              status                               | 8
968  * +----------------+----------------+----------------+----------------+
969  *
970  * id - uint16_t, copied from the request.
971  * operation - uint8_t, XENCAMERA_OP_* - copied from request.
972  * status - int32_t, response status, zero on success and -XEN_EXX on failure.
973  *
974  *
975  * Configuration response - response for XENCAMERA_OP_CONFIG_SET,
976  * XENCAMERA_OP_CONFIG_GET and XENCAMERA_OP_CONFIG_VALIDATE requests:
977  *         0                1                 2               3        octet
978  * +----------------+----------------+----------------+----------------+
979  * |               id                | _OP_CONFIG_XXX |    reserved    | 4
980  * +----------------+----------------+----------------+----------------+
981  * |                               status                              | 8
982  * +----------------+----------------+----------------+----------------+
983  * |                            pixel format                           | 12
984  * +----------------+----------------+----------------+----------------+
985  * |                               width                               | 16
986  * +----------------+----------------+----------------+----------------+
987  * |                               height                              | 20
988  * +----------------+----------------+----------------+----------------+
989  * |                             colorspace                            | 24
990  * +----------------+----------------+----------------+----------------+
991  * |                             xfer_func                             | 28
992  * +----------------+----------------+----------------+----------------+
993  * |                             ycbcr_enc                             | 32
994  * +----------------+----------------+----------------+----------------+
995  * |                            quantization                           | 36
996  * +----------------+----------------+----------------+----------------+
997  * |                       displ_asp_ratio_numer                       | 40
998  * +----------------+----------------+----------------+----------------+
999  * |                       displ_asp_ratio_denom                       | 44
1000  * +----------------+----------------+----------------+----------------+
1001  * |                          frame_rate_numer                         | 48
1002  * +----------------+----------------+----------------+----------------+
1003  * |                          frame_rate_denom                         | 52
1004  * +----------------+----------------+----------------+----------------+
1005  * |                             reserved                              | 56
1006  * +----------------+----------------+----------------+----------------+
1007  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
1008  * +----------------+----------------+----------------+----------------+
1009  * |                             reserved                              | 64
1010  * +----------------+----------------+----------------+----------------+
1011  *
1012  * Meaning of the corresponding values in this response is the same as for
1013  * XENCAMERA_OP_CONFIG_SET and XENCAMERA_OP_FRAME_RATE_SET requests.
1014  *
1015  * colorspace - uint32_t, this supplements pixel_format parameter,
1016  *   one of the XENCAMERA_COLORSPACE_XXX.
1017  * xfer_func - uint32_t, this supplements colorspace parameter,
1018  *   one of the XENCAMERA_XFER_FUNC_XXX.
1019  * ycbcr_enc - uint32_t, this supplements colorspace parameter,
1020  *   one of the XENCAMERA_YCBCR_ENC_XXX. Please note, that ycbcr_enc is only
1021  *   valid for YCbCr pixelformats and should be ignored otherwise.
1022  * quantization - uint32_t, this supplements colorspace parameter,
1023  *   one of the XENCAMERA_QUANTIZATION_XXX.
1024  * displ_asp_ratio_numer - uint32_t, numerator of the display aspect ratio.
1025  * displ_asp_ratio_denom - uint32_t, denominator of the display aspect ratio.
1026  */
1027 struct xencamera_config_resp {
1028     uint32_t pixel_format;
1029     uint32_t width;
1030     uint32_t height;
1031     uint32_t colorspace;
1032     uint32_t xfer_func;
1033     uint32_t ycbcr_enc;
1034     uint32_t quantization;
1035     uint32_t displ_asp_ratio_numer;
1036     uint32_t displ_asp_ratio_denom;
1037     uint32_t frame_rate_numer;
1038     uint32_t frame_rate_denom;
1039 };
1040 
1041 /*
1042  * Request buffer response - response for XENCAMERA_OP_BUF_GET_LAYOUT
1043  * request:
1044  *         0                1                 2               3        octet
1045  * +----------------+----------------+----------------+----------------+
1046  * |               id                |_BUF_GET_LAYOUT |    reserved    | 4
1047  * +----------------+----------------+----------------+----------------+
1048  * |                               status                              | 8
1049  * +----------------+----------------+----------------+----------------+
1050  * |   num_planes   |                     reserved                     | 12
1051  * +----------------+----------------+----------------+----------------+
1052  * |                                size                               | 16
1053  * +----------------+----------------+----------------+----------------+
1054  * |                           plane_size[0]                           | 20
1055  * +----------------+----------------+----------------+----------------+
1056  * |                           plane_size[1]                           | 24
1057  * +----------------+----------------+----------------+----------------+
1058  * |                           plane_size[2]                           | 28
1059  * +----------------+----------------+----------------+----------------+
1060  * |                           plane_size[3]                           | 32
1061  * +----------------+----------------+----------------+----------------+
1062  * |                          plane_stride[0]                          | 36
1063  * +----------------+----------------+----------------+----------------+
1064  * |                          plane_stride[1]                          | 40
1065  * +----------------+----------------+----------------+----------------+
1066  * |                          plane_stride[2]                          | 44
1067  * +----------------+----------------+----------------+----------------+
1068  * |                          plane_stride[3]                          | 48
1069  * +----------------+----------------+----------------+----------------+
1070  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
1071  * +----------------+----------------+----------------+----------------+
1072  * |                             reserved                              | 64
1073  * +----------------+----------------+----------------+----------------+
1074  *
1075  * num_planes - uint8_t, number of planes of the buffer.
1076  * size - uint32_t, overall size of the buffer including sizes of the
1077  *   individual planes and padding if applicable.
1078  * plane_size - array of uint32_t, size in octets of the corresponding plane
1079  *   including padding.
1080  * plane_stride - array of uint32_t, size in octets occupied by the
1081  *   corresponding single image line including padding if applicable.
1082  *
1083  * Note! The sizes and strides in this response apply to all buffers created
1084  * with XENCAMERA_OP_BUF_CREATE command, but individual buffers may have
1085  * different plane offsets, see XENCAMERA_OP_BUF_REQUEST.plane_offset.
1086  */
1087 struct xencamera_buf_get_layout_resp {
1088     uint8_t num_planes;
1089     uint8_t reserved[3];
1090     uint32_t size;
1091     uint32_t plane_size[XENCAMERA_MAX_PLANE];
1092     uint32_t plane_stride[XENCAMERA_MAX_PLANE];
1093 };
1094 
1095 /*
1096  * Request buffer response - response for XENCAMERA_OP_BUF_REQUEST
1097  * request:
1098  *         0                1                 2               3        octet
1099  * +----------------+----------------+----------------+----------------+
1100  * |               id                |_OP_BUF_REQUEST |    reserved    | 4
1101  * +----------------+----------------+----------------+----------------+
1102  * |                               status                              | 8
1103  * +----------------+----------------+----------------+----------------+
1104  * |   num_buffers  |                     reserved                     | 12
1105  * +----------------+----------------+----------------+----------------+
1106  * |                             reserved                              | 16
1107  * +----------------+----------------+----------------+----------------+
1108  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
1109  * +----------------+----------------+----------------+----------------+
1110  * |                             reserved                              | 64
1111  * +----------------+----------------+----------------+----------------+
1112  *
1113  * num_buffers - uint8_t, number of buffers to be used.
1114  *
1115  *
1116  * Control enumerate response - response for XENCAMERA_OP_CTRL_ENUM:
1117  *         0                1                 2               3        octet
1118  * +----------------+----------------+----------------+----------------+
1119  * |               id                | _OP_CTRL_ENUM  |    reserved    | 4
1120  * +----------------+----------------+----------------+----------------+
1121  * |                               status                              | 8
1122  * +----------------+----------------+----------------+----------------+
1123  * |     index      |      type      |            reserved             | 12
1124  * +----------------+----------------+----------------+----------------+
1125  * |                               flags                               | 16
1126  * +----------------+----------------+----------------+----------------+
1127  * |                          min low 32-bits                          | 20
1128  * +----------------+----------------+----------------+----------------+
1129  * |                          min high 32-bits                         | 24
1130  * +----------------+----------------+----------------+----------------+
1131  * |                          max low 32-bits                          | 28
1132  * +----------------+----------------+----------------+----------------+
1133  * |                          max high 32-bits                         | 32
1134  * +----------------+----------------+----------------+----------------+
1135  * |                         step low 32-bits                          | 36
1136  * +----------------+----------------+----------------+----------------+
1137  * |                         step high 32-bits                         | 40
1138  * +----------------+----------------+----------------+----------------+
1139  * |                        def_val low 32-bits                        | 44
1140  * +----------------+----------------+----------------+----------------+
1141  * |                        def_val high 32-bits                       | 48
1142  * +----------------+----------------+----------------+----------------+
1143  * |                             reserved                              | 52
1144  * +----------------+----------------+----------------+----------------+
1145  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
1146  * +----------------+----------------+----------------+----------------+
1147  * |                             reserved                              | 64
1148  * +----------------+----------------+----------------+----------------+
1149  *
1150  * index - uint8_t, index of the camera control in response.
1151  * type - uint8_t, type of the control, one of the XENCAMERA_CTRL_XXX.
1152  * flags - uint32_t, flags of the control, one of the XENCAMERA_CTRL_FLG_XXX.
1153  * min - int64_t, minimum value of the control.
1154  * max - int64_t, maximum value of the control.
1155  * step - int64_t, minimum size in which control value can be changed.
1156  * def_val - int64_t, default value of the control.
1157  */
1158 struct xencamera_ctrl_enum_resp {
1159     uint8_t index;
1160     uint8_t type;
1161     uint8_t reserved[2];
1162     uint32_t flags;
1163     int64_t min;
1164     int64_t max;
1165     int64_t step;
1166     int64_t def_val;
1167 };
1168 
1169 /*
1170  * Get control response - response for XENCAMERA_OP_CTRL_GET:
1171  *         0                1                 2               3        octet
1172  * +----------------+----------------+----------------+----------------+
1173  * |               id                | _OP_CTRL_GET   |    reserved    | 4
1174  * +----------------+----------------+----------------+----------------+
1175  * |                               status                              | 8
1176  * +----------------+----------------+----------------+----------------+
1177  * |       type     |                     reserved                     | 12
1178  * +----------------+----------------+----------------+----------------+
1179  * |                             reserved                              | 16
1180  * +----------------+----------------+----------------+----------------+
1181  * |                             reserved                              | 20
1182  * +----------------+----------------+----------------+----------------+
1183  * |                          value low 32-bit                         | 24
1184  * +----------------+----------------+----------------+----------------+
1185  * |                          value high 32-bit                        | 28
1186  * +----------------+----------------+----------------+----------------+
1187  * |                             reserved                              | 32
1188  * +----------------+----------------+----------------+----------------+
1189  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
1190  * +----------------+----------------+----------------+----------------+
1191  * |                             reserved                              | 64
1192  * +----------------+----------------+----------------+----------------+
1193  *
1194  * type - uint8_t, type of the control, one of the XENCAMERA_CTRL_XXX.
1195  * value - int64_t, new value of the control.
1196  */
1197 
1198 /*
1199  *----------------------------------- Events ----------------------------------
1200  *
1201  * Events are sent via a shared page allocated by the front and propagated by
1202  *   evt-event-channel/evt-ring-ref XenStore entries.
1203  *
1204  * All event packets have the same length (64 octets).
1205  * All event packets have common header:
1206  *         0                1                 2               3        octet
1207  * +----------------+----------------+----------------+----------------+
1208  * |               id                |      type      |   reserved     | 4
1209  * +----------------+----------------+----------------+----------------+
1210  * |                             reserved                              | 8
1211  * +----------------+----------------+----------------+----------------+
1212  *
1213  * id - uint16_t, event id, may be used by front.
1214  * type - uint8_t, type of the event.
1215  *
1216  *
1217  * Frame captured event - event from back to front when a new captured
1218  * frame is available:
1219  *         0                1                 2               3        octet
1220  * +----------------+----------------+----------------+----------------+
1221  * |               id                |_EVT_FRAME_AVAIL|   reserved     | 4
1222  * +----------------+----------------+----------------+----------------+
1223  * |                             reserved                              | 8
1224  * +----------------+----------------+----------------+----------------+
1225  * |      index     |                     reserved                     | 12
1226  * +----------------+----------------+----------------+----------------+
1227  * |                              used_sz                              | 16
1228  * +----------------+----------------+----------------+----------------+
1229  * |                              seq_num                              | 20
1230  * +----------------+----------------+----------------+----------------+
1231  * |                             reserved                              | 24
1232  * +----------------+----------------+----------------+----------------+
1233  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
1234  * +----------------+----------------+----------------+----------------+
1235  * |                             reserved                              | 64
1236  * +----------------+----------------+----------------+----------------+
1237  *
1238  * index - uint8_t, index of the buffer that contains new captured frame,
1239  *   see XENCAMERA_OP_BUF_CREATE description on the range
1240  * used_sz - uint32_t, number of octets this frame has. This can be less
1241  * than the XENCAMERA_OP_BUF_REQUEST.size (response) for compressed formats.
1242  * seq_num - uint32_t, sequential number of the frame. Must be
1243  *   monotonically increasing. If skips are detected in seq_num then that
1244  *   means that the frames in-between were dropped. Note however that not
1245  *   all video capture hardware is capable of detecting dropped frames.
1246  *   In that case there will be no skips in the sequence counter.
1247  */
1248 struct xencamera_frame_avail_evt {
1249     uint8_t index;
1250     uint8_t reserved[3];
1251     uint32_t used_sz;
1252     uint32_t seq_num;
1253 };
1254 
1255 /*
1256  * Control change event- event from back to front when camera control
1257  * has changed:
1258  *         0                1                 2               3        octet
1259  * +----------------+----------------+----------------+----------------+
1260  * |               id                |_EVT_CTRL_CHANGE|   reserved     | 4
1261  * +----------------+----------------+----------------+----------------+
1262  * |       type     |                     reserved                     | 8
1263  * +----------------+----------------+----------------+----------------+
1264  * |                             reserved                              | 12
1265  * +----------------+----------------+----------------+----------------+
1266  * |                             reserved                              | 16
1267  * +----------------+----------------+----------------+----------------+
1268  * |                          value low 32-bit                         | 20
1269  * +----------------+----------------+----------------+----------------+
1270  * |                          value high 32-bit                        | 24
1271  * +----------------+----------------+----------------+----------------+
1272  * |                             reserved                              | 28
1273  * +----------------+----------------+----------------+----------------+
1274  * |/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/|
1275  * +----------------+----------------+----------------+----------------+
1276  * |                             reserved                              | 64
1277  * +----------------+----------------+----------------+----------------+
1278  *
1279  * type - uint8_t, type of the control, one of the XENCAMERA_CTRL_XXX.
1280  * value - int64_t, new value of the control.
1281  *
1282  * Notes:
1283  *  - this event is not sent for write-only controls
1284  *  - this event is not sent to the originator of the control change
1285  *  - this event is not sent when frontend first connects, e.g. initial
1286  *    control state must be explicitly queried
1287  */
1288 
1289 struct xencamera_req {
1290     uint16_t id;
1291     uint8_t operation;
1292     uint8_t reserved[5];
1293     union {
1294         struct xencamera_config_req config;
1295         struct xencamera_frame_rate_req frame_rate;
1296         struct xencamera_buf_request buf_request;
1297         struct xencamera_buf_create_req buf_create;
1298         struct xencamera_index index;
1299         struct xencamera_ctrl_value ctrl_value;
1300         struct xencamera_get_ctrl_req get_ctrl;
1301         uint8_t reserved[56];
1302     } req;
1303 };
1304 
1305 struct xencamera_resp {
1306     uint16_t id;
1307     uint8_t operation;
1308     uint8_t reserved;
1309     int32_t status;
1310     union {
1311         struct xencamera_config_resp config;
1312         struct xencamera_buf_get_layout_resp buf_layout;
1313         struct xencamera_buf_request buf_request;
1314         struct xencamera_ctrl_enum_resp ctrl_enum;
1315         struct xencamera_ctrl_value ctrl_value;
1316         uint8_t reserved1[56];
1317     } resp;
1318 };
1319 
1320 struct xencamera_evt {
1321     uint16_t id;
1322     uint8_t type;
1323     uint8_t reserved[5];
1324     union {
1325         struct xencamera_frame_avail_evt frame_avail;
1326         struct xencamera_ctrl_value ctrl_value;
1327         uint8_t reserved[56];
1328     } evt;
1329 };
1330 
1331 DEFINE_RING_TYPES(xen_cameraif, struct xencamera_req, struct xencamera_resp);
1332 
1333 /*
1334  ******************************************************************************
1335  *                        Back to front events delivery
1336  ******************************************************************************
1337  * In order to deliver asynchronous events from back to front a shared page is
1338  * allocated by front and its granted reference propagated to back via
1339  * XenStore entries (evt-ring-ref/evt-event-channel).
1340  * This page has a common header used by both front and back to synchronize
1341  * access and control event's ring buffer, while back being a producer of the
1342  * events and front being a consumer. The rest of the page after the header
1343  * is used for event packets.
1344  *
1345  * Upon reception of an event(s) front may confirm its reception
1346  * for either each event, group of events or none.
1347  */
1348 
1349 struct xencamera_event_page {
1350     uint32_t in_cons;
1351     uint32_t in_prod;
1352     uint8_t reserved[56];
1353 };
1354 
1355 #define XENCAMERA_EVENT_PAGE_SIZE 4096
1356 #define XENCAMERA_IN_RING_OFFS (sizeof(struct xencamera_event_page))
1357 #define XENCAMERA_IN_RING_SIZE (XENCAMERA_EVENT_PAGE_SIZE - XENCAMERA_IN_RING_OFFS)
1358 #define XENCAMERA_IN_RING_LEN (XENCAMERA_IN_RING_SIZE / sizeof(struct xencamera_evt))
1359 #define XENCAMERA_IN_RING(page) \
1360     ((struct xencamera_evt *)((char *)(page) + XENCAMERA_IN_RING_OFFS))
1361 #define XENCAMERA_IN_RING_REF(page, idx) \
1362     (XENCAMERA_IN_RING((page))[(idx) % XENCAMERA_IN_RING_LEN])
1363 
1364 #endif /* __XEN_PUBLIC_IO_CAMERAIF_H__ */
1365 
1366 /*
1367  * Local variables:
1368  * mode: C
1369  * c-file-style: "BSD"
1370  * c-basic-offset: 4
1371  * tab-width: 4
1372  * indent-tabs-mode: nil
1373  * End:
1374  */
1375