Commit | Line | Data |
---|---|---|
77f926cd LQ |
1 | /* |
2 | * Copyright (c) 2015-2016, Linaro Limited | |
3 | * | |
4 | * This software is licensed under the terms of the GNU General Public | |
5 | * License version 2, as published by the Free Software Foundation, and | |
6 | * may be copied, distributed, and modified under those terms. | |
7 | * | |
8 | * This program is distributed in the hope that it will be useful, | |
9 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
10 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
11 | * GNU General Public License for more details. | |
12 | * | |
13 | */ | |
14 | #ifndef TEE_PRIVATE_H | |
15 | #define TEE_PRIVATE_H | |
16 | ||
17 | #include <linux/cdev.h> | |
18 | #include <linux/completion.h> | |
19 | #include <linux/device.h> | |
20 | #include <linux/kref.h> | |
21 | #include <linux/mutex.h> | |
22 | #include <linux/types.h> | |
23 | ||
24 | struct tee_device; | |
25 | ||
26 | /** | |
27 | * struct tee_shm - shared memory object | |
28 | * @teedev: device used to allocate the object | |
29 | * @ctx: context using the object, if NULL the context is gone | |
30 | * @link link element | |
31 | * @paddr: physical address of the shared memory | |
32 | * @kaddr: virtual address of the shared memory | |
33 | * @size: size of shared memory | |
34 | * @dmabuf: dmabuf used to for exporting to user space | |
35 | * @flags: defined by TEE_SHM_* in tee_drv.h | |
36 | * @id: unique id of a shared memory object on this device | |
37 | */ | |
38 | struct tee_shm { | |
39 | struct tee_device *teedev; | |
40 | struct tee_context *ctx; | |
41 | struct list_head link; | |
42 | phys_addr_t paddr; | |
43 | void *kaddr; | |
44 | size_t size; | |
45 | struct dma_buf *dmabuf; | |
46 | u32 flags; | |
47 | int id; | |
48 | }; | |
49 | ||
50 | struct tee_shm_pool_mgr; | |
51 | ||
52 | /** | |
53 | * struct tee_shm_pool_mgr_ops - shared memory pool manager operations | |
54 | * @alloc: called when allocating shared memory | |
55 | * @free: called when freeing shared memory | |
56 | */ | |
57 | struct tee_shm_pool_mgr_ops { | |
58 | int (*alloc)(struct tee_shm_pool_mgr *poolmgr, struct tee_shm *shm, | |
59 | size_t size); | |
60 | void (*free)(struct tee_shm_pool_mgr *poolmgr, struct tee_shm *shm); | |
61 | }; | |
62 | ||
63 | /** | |
64 | * struct tee_shm_pool_mgr - shared memory manager | |
65 | * @ops: operations | |
66 | * @private_data: private data for the shared memory manager | |
67 | */ | |
68 | struct tee_shm_pool_mgr { | |
69 | const struct tee_shm_pool_mgr_ops *ops; | |
70 | void *private_data; | |
71 | }; | |
72 | ||
73 | /** | |
74 | * struct tee_shm_pool - shared memory pool | |
75 | * @private_mgr: pool manager for shared memory only between kernel | |
76 | * and secure world | |
77 | * @dma_buf_mgr: pool manager for shared memory exported to user space | |
78 | * @destroy: called when destroying the pool | |
79 | * @private_data: private data for the pool | |
80 | */ | |
81 | struct tee_shm_pool { | |
82 | struct tee_shm_pool_mgr private_mgr; | |
83 | struct tee_shm_pool_mgr dma_buf_mgr; | |
84 | void (*destroy)(struct tee_shm_pool *pool); | |
85 | void *private_data; | |
86 | }; | |
87 | ||
88 | #define TEE_DEVICE_FLAG_REGISTERED 0x1 | |
89 | #define TEE_MAX_DEV_NAME_LEN 32 | |
90 | ||
91 | /** | |
92 | * struct tee_device - TEE Device representation | |
93 | * @name: name of device | |
94 | * @desc: description of device | |
95 | * @id: unique id of device | |
96 | * @flags: represented by TEE_DEVICE_FLAG_REGISTERED above | |
97 | * @dev: embedded basic device structure | |
98 | * @cdev: embedded cdev | |
99 | * @num_users: number of active users of this device | |
100 | * @c_no_user: completion used when unregistering the device | |
101 | * @mutex: mutex protecting @num_users and @idr | |
102 | * @idr: register of shared memory object allocated on this device | |
103 | * @pool: shared memory pool | |
104 | */ | |
105 | struct tee_device { | |
106 | char name[TEE_MAX_DEV_NAME_LEN]; | |
107 | const struct tee_desc *desc; | |
108 | int id; | |
109 | unsigned int flags; | |
110 | ||
111 | struct device dev; | |
112 | struct cdev cdev; | |
113 | ||
114 | size_t num_users; | |
115 | struct completion c_no_users; | |
116 | struct mutex mutex; /* protects num_users and idr */ | |
117 | ||
118 | struct idr idr; | |
119 | struct tee_shm_pool *pool; | |
120 | }; | |
121 | ||
122 | int tee_shm_init(void); | |
123 | ||
124 | int tee_shm_get_fd(struct tee_shm *shm); | |
125 | ||
126 | bool tee_device_get(struct tee_device *teedev); | |
127 | void tee_device_put(struct tee_device *teedev); | |
128 | ||
129 | #endif /*TEE_PRIVATE_H*/ |