aboutsummaryrefslogtreecommitdiff
path: root/drivers/misc/mediatek/mjc/mt6735/mjc_kernel_driver.h
blob: c4ab7f2256344f638dca03d278794a21403e0c18 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#ifndef __MJC_KERNEL_DRIVER_H__
#define __MJC_KERNEL_DRIVER_H__

typedef struct _MJC_EVENT_T
{
    void *pvWaitQueue;             ///< [IN]     The waitqueue discription
    unsigned int u4TimeoutMs;            ///< [IN]     The timeout ms
    void *pvFlag;                  ///< [IN/OUT] flag
} MJC_EVENT_T;

typedef struct
{
    MJC_EVENT_T rEvent;
} MJC_CONTEXT_T;

//************************************
// IO control structure
//************************************
typedef struct 
{
    unsigned int u4StructSize;
} MJC_IOCTL_LOCK_HW_T;

typedef struct
{
    unsigned int u4StructSize;
	unsigned int u4TimeoutMs;
} MJC_IOCTL_ISR_T;

typedef struct
{
    unsigned long reg;
    unsigned int val;
    unsigned int mask;
} MJC_WRITE_REG_T;

typedef struct
{
    unsigned long reg;
    unsigned int val;
    unsigned int mask;
} MJC_READ_REG_T;

typedef struct
{
    unsigned int u4StructSize;
    unsigned short u2OutputFramerate;
} MJC_IOCTL_SRC_CLK_T;

typedef struct
{
    unsigned int u4StructSize;
    unsigned long ulRegPAddress;
	unsigned long ulRegPSize;
} MJC_IOCTL_REG_INFO_T;

#define MJC_IOC_MAGIC    'N'

#define MJC_LOCKHW                           _IOW(MJC_IOC_MAGIC, 0x00, MJC_IOCTL_LOCK_HW_T)
#define MJC_WAITISR                          _IOW(MJC_IOC_MAGIC, 0x01, MJC_IOCTL_ISR_T)
#define MJC_READ_REG                         _IOW(MJC_IOC_MAGIC, 0x02, MJC_READ_REG_T)
#define MJC_WRITE_REG                        _IOW(MJC_IOC_MAGIC, 0x03, MJC_WRITE_REG_T)
#define MJC_WRITE_REG_TBL                   _IOW(MJC_IOC_MAGIC, 0x04, int)
#define MJC_CLEAR_REG_TBL                   _IOW(MJC_IOC_MAGIC, 0x05, int)
#define MJC_SOURCE_CLK                      _IOW(MJC_IOC_MAGIC, 0x06, MJC_IOCTL_SRC_CLK_T)
#define MJC_REG_INFO                      _IOW(MJC_IOC_MAGIC, 0x07, MJC_IOCTL_REG_INFO_T)

#endif //__MJC_KERNEL_DRIVER_H__