hc
2024-01-03 2f7c68cb55ecb7331f2381deb497c27155f32faf
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
69
70
71
72
73
74
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Copyright 2013-2016 Freescale Semiconductor Inc.
 * Copyright 2016-2018 NXP
 */
 
#ifndef _FSL_DPRTC_CMD_H
#define _FSL_DPRTC_CMD_H
 
/* Command versioning */
#define DPRTC_CMD_BASE_VERSION        1
#define DPRTC_CMD_VERSION_2        2
#define DPRTC_CMD_ID_OFFSET        4
 
#define DPRTC_CMD(id)    (((id) << DPRTC_CMD_ID_OFFSET) | DPRTC_CMD_BASE_VERSION)
#define DPRTC_CMD_V2(id) (((id) << DPRTC_CMD_ID_OFFSET) | DPRTC_CMD_VERSION_2)
 
/* Command IDs */
#define DPRTC_CMDID_CLOSE            DPRTC_CMD(0x800)
#define DPRTC_CMDID_OPEN            DPRTC_CMD(0x810)
 
#define DPRTC_CMDID_SET_IRQ_ENABLE        DPRTC_CMD(0x012)
#define DPRTC_CMDID_GET_IRQ_ENABLE        DPRTC_CMD(0x013)
#define DPRTC_CMDID_SET_IRQ_MASK        DPRTC_CMD_V2(0x014)
#define DPRTC_CMDID_GET_IRQ_MASK        DPRTC_CMD(0x015)
#define DPRTC_CMDID_GET_IRQ_STATUS        DPRTC_CMD(0x016)
#define DPRTC_CMDID_CLEAR_IRQ_STATUS        DPRTC_CMD(0x017)
 
#pragma pack(push, 1)
struct dprtc_cmd_open {
   __le32 dprtc_id;
};
 
struct dprtc_cmd_get_irq {
   __le32 pad;
   u8 irq_index;
};
 
struct dprtc_cmd_set_irq_enable {
   u8 en;
   u8 pad[3];
   u8 irq_index;
};
 
struct dprtc_rsp_get_irq_enable {
   u8 en;
};
 
struct dprtc_cmd_set_irq_mask {
   __le32 mask;
   u8 irq_index;
};
 
struct dprtc_rsp_get_irq_mask {
   __le32 mask;
};
 
struct dprtc_cmd_get_irq_status {
   __le32 status;
   u8 irq_index;
};
 
struct dprtc_rsp_get_irq_status {
   __le32 status;
};
 
struct dprtc_cmd_clear_irq_status {
   __le32 status;
   u8 irq_index;
};
 
#pragma pack(pop)
 
#endif /* _FSL_DPRTC_CMD_H */