18611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/****************************************************************************
28611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ****************************************************************************
38611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***
48611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   This header was automatically generated from a Linux kernel header
58611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   of the same name, to make information necessary for userspace to
68611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   call into the kernel available to libc.  It contains only constants,
78611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   structures, and macros generated from the original header, and thus,
88611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   contains no copyrightable information.
98611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***
108611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   To edit the content of this header, modify the corresponding
118611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   source file (e.g. under external/kernel-headers/original/) then
128611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   run bionic/libc/kernel/tools/update_all.py
138611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***
148611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   Any manual change here will be lost the next time this script will
158611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***   be run. You've been warned!
168611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ***
178611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ****************************************************************************
188611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu ****************************************************************************/
198611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#ifndef __LINUX_MSM_GEMINI_H
208611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define __LINUX_MSM_GEMINI_H
218611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#include <linux/types.h>
228611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#include <linux/ioctl.h>
238611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
248611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_MAGIC 'g'
258611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_GET_HW_VERSION   _IOW(MSM_GMN_IOCTL_MAGIC, 1, struct msm_gemini_hw_cmd *)
268611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_RESET   _IOW(MSM_GMN_IOCTL_MAGIC, 2, struct msm_gemini_ctrl_cmd *)
278611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_STOP   _IOW(MSM_GMN_IOCTL_MAGIC, 3, struct msm_gemini_hw_cmds *)
288611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
298611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_START   _IOW(MSM_GMN_IOCTL_MAGIC, 4, struct msm_gemini_hw_cmds *)
308611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_INPUT_BUF_ENQUEUE   _IOW(MSM_GMN_IOCTL_MAGIC, 5, struct msm_gemini_buf *)
318611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_INPUT_GET   _IOW(MSM_GMN_IOCTL_MAGIC, 6, struct msm_gemini_buf *)
328611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_INPUT_GET_UNBLOCK   _IOW(MSM_GMN_IOCTL_MAGIC, 7, int)
338611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
348611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_OUTPUT_BUF_ENQUEUE   _IOW(MSM_GMN_IOCTL_MAGIC, 8, struct msm_gemini_buf *)
358611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_OUTPUT_GET   _IOW(MSM_GMN_IOCTL_MAGIC, 9, struct msm_gemini_buf *)
368611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_OUTPUT_GET_UNBLOCK   _IOW(MSM_GMN_IOCTL_MAGIC, 10, int)
378611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_EVT_GET   _IOW(MSM_GMN_IOCTL_MAGIC, 11, struct msm_gemini_ctrl_cmd *)
388611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
398611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_EVT_GET_UNBLOCK   _IOW(MSM_GMN_IOCTL_MAGIC, 12, int)
408611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_HW_CMD   _IOW(MSM_GMN_IOCTL_MAGIC, 13, struct msm_gemini_hw_cmd *)
418611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_HW_CMDS   _IOW(MSM_GMN_IOCTL_MAGIC, 14, struct msm_gemini_hw_cmds *)
428611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GMN_IOCTL_TEST_DUMP_REGION   _IOW(MSM_GMN_IOCTL_MAGIC, 15, unsigned long)
438611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
448611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_MODE_REALTIME_ENCODE 0
458611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_MODE_OFFLINE_ENCODE 1
468611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_MODE_REALTIME_ROTATION 2
478611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_MODE_OFFLINE_ROTATION 3
488611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
498611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsustruct msm_gemini_ctrl_cmd {
508611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t type;
518611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t len;
528611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu void *value;
538611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
548611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu};
558611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_EVT_RESET 0
568611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_EVT_FRAMEDONE 1
578611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_EVT_ERR 2
588611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
598611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsustruct msm_gemini_buf {
608611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t type;
618611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu int fd;
628611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu void *vaddr;
638611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
648611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t y_off;
658611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t y_len;
668611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t framedone_len;
678611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t cbcr_off;
688611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
698611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t cbcr_len;
708611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t num_of_mcu_rows;
718611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t offset;
728611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu};
738611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
748611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_HW_CMD_TYPE_READ 0
758611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_HW_CMD_TYPE_WRITE 1
768611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_HW_CMD_TYPE_WRITE_OR 2
778611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_HW_CMD_TYPE_UWAIT 3
788611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
798611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_HW_CMD_TYPE_MWAIT 4
808611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_HW_CMD_TYPE_MDELAY 5
818611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_GEMINI_HW_CMD_TYPE_UDELAY 6
828611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsustruct msm_gemini_hw_cmd {
838611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
848611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t type:4;
858611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t n:12;
868611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t offset:16;
878611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t mask;
888611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
898611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu union {
908611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t data;
918611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t *pdata;
928611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu };
938611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
948611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu};
958611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsustruct msm_gemini_hw_cmds {
968611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t m;
978611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu struct msm_gemini_hw_cmd hw_cmd[1];
988611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
998611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu};
1008611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#endif
101f0edc3f155a136d87beccd5ecef75c2d4b6f6b64Iliyan Malchev
102