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__
|