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_MERCURY_H
208611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define __LINUX_MSM_MERCURY_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_MERCURY_HW_VERSION_REG 0x0004
258611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define OUTPUT_H2V1 0
268611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define OUTPUT_H2V2 1
278611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define OUTPUT_BYTE 6
288611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
298611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_MODE_REALTIME_ENCODE 0
308611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_MODE_OFFLINE_ENCODE 1
318611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_MODE_REALTIME_ROTATION 2
328611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_MODE_OFFLINE_ROTATION 3
338611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
348611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_EVT_RESET 1
358611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_EVT_FRAMEDONE 2
368611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_EVT_ERR 3
378611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_EVT_UNBLOCK 4
388611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
398611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_HW_CMD_TYPE_READ 0
408611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_HW_CMD_TYPE_WRITE 1
418611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_HW_CMD_TYPE_WRITE_OR 2
428611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_HW_CMD_TYPE_UWAIT 3
438611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
448611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_HW_CMD_TYPE_MWAIT 4
458611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_HW_CMD_TYPE_MDELAY 5
468611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MERCURY_HW_CMD_TYPE_UDELAY 6
478611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_MAGIC 'g'
488611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
498611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_GET_HW_VERSION   _IOW(MSM_MCR_IOCTL_MAGIC, 1, struct msm_mercury_hw_cmd *)
508611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_RESET   _IOW(MSM_MCR_IOCTL_MAGIC, 2, struct msm_mercury_ctrl_cmd *)
518611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_STOP   _IOW(MSM_MCR_IOCTL_MAGIC, 3, struct msm_mercury_hw_cmds *)
528611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_START   _IOW(MSM_MCR_IOCTL_MAGIC, 4, struct msm_mercury_hw_cmds *)
538611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
548611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_INPUT_BUF_CFG   _IOW(MSM_MCR_IOCTL_MAGIC, 5, struct msm_mercury_buf *)
558611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_INPUT_GET   _IOW(MSM_MCR_IOCTL_MAGIC, 6, struct msm_mercury_buf *)
568611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_INPUT_GET_UNBLOCK   _IOW(MSM_MCR_IOCTL_MAGIC, 7, int)
578611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_OUTPUT_BUF_CFG   _IOW(MSM_MCR_IOCTL_MAGIC, 8, struct msm_mercury_buf *)
588611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
598611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_OUTPUT_GET   _IOW(MSM_MCR_IOCTL_MAGIC, 9, struct msm_mercury_buf *)
608611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_OUTPUT_GET_UNBLOCK   _IOW(MSM_MCR_IOCTL_MAGIC, 10, int)
618611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_EVT_GET   _IOW(MSM_MCR_IOCTL_MAGIC, 11, struct msm_mercury_ctrl_cmd *)
628611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_EVT_GET_UNBLOCK   _IOW(MSM_MCR_IOCTL_MAGIC, 12, int)
638611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
648611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_HW_CMD   _IOW(MSM_MCR_IOCTL_MAGIC, 13, struct msm_mercury_hw_cmd *)
658611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_HW_CMDS   _IOW(MSM_MCR_IOCTL_MAGIC, 14, struct msm_mercury_hw_cmds *)
668611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#define MSM_MCR_IOCTL_TEST_DUMP_REGION   _IOW(MSM_MCR_IOCTL_MAGIC, 15, unsigned long)
678611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsustruct msm_mercury_ctrl_cmd {
688611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
698611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t type;
708611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t len;
718611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu void *value;
728611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu};
738611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
748611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsustruct msm_mercury_buf {
758611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t type;
768611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu int fd;
778611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu void *vaddr;
788611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
798611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t y_off;
808611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t y_len;
818611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t framedone_len;
828611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t cbcr_off;
838611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
848611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t cbcr_len;
858611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t num_of_mcu_rows;
868611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t offset;
878611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu};
888611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
898611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsustruct msm_mercury_hw_cmd {
908611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t type:4;
918611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t n:12;
928611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t offset:16;
938611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
948611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t mask;
958611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu union {
968611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t data;
978611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t *pdata;
988611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
998611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu };
1008611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu};
1018611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsustruct msm_mercury_hw_cmds {
1028611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu uint32_t m;
1038611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
1048611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu struct msm_mercury_hw_cmd hw_cmd[1];
1058611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu};
1068611d5578ff014a1415b26e75e63aecbc4ad266cBrian Muramatsu#endif
107f0edc3f155a136d87beccd5ecef75c2d4b6f6b64Iliyan Malchev
108