ReactOS 0.4.16-dev-1605-g7dd1858
osi.c
Go to the documentation of this file.
7#include <uacpi/kernel_api.h>
8
9#ifndef UACPI_BAREBONES_MODE
10
15
16 // Only applicable for predefined host interfaces
18
19 // Only applicable for predefined interfaces
22
24};
25
30
31#define WINDOWS(string, interface) \
32 { \
33 .name = "Windows "string, \
34 .weight = UACPI_VENDOR_INTERFACE_WINDOWS_##interface, \
35 .kind = UACPI_INTERFACE_KIND_VENDOR, \
36 .host_type = 0, \
37 .disabled = 0, \
38 .dynamic = 0, \
39 .next = UACPI_NULL \
40 }
41
42#define HOST_FEATURE(string, type) \
43 { \
44 .name = string, \
45 .weight = 0, \
46 .kind = UACPI_INTERFACE_KIND_FEATURE, \
47 .host_type = UACPI_HOST_INTERFACE_##type, \
48 .disabled = 1, \
49 .dynamic = 0, \
50 .next = UACPI_NULL, \
51 }
52
54 // Vendor strings
55 WINDOWS("2000", 2000),
56 WINDOWS("2001", XP),
57 WINDOWS("2001 SP1", XP_SP1),
58 WINDOWS("2001.1", SERVER_2003),
59 WINDOWS("2001 SP2", XP_SP2),
60 WINDOWS("2001.1 SP1", SERVER_2003_SP1),
61 WINDOWS("2006", VISTA),
62 WINDOWS("2006.1", SERVER_2008),
63 WINDOWS("2006 SP1", VISTA_SP1),
64 WINDOWS("2006 SP2", VISTA_SP2),
65 WINDOWS("2009", 7),
66 WINDOWS("2012", 8),
67 WINDOWS("2013", 8_1),
68 WINDOWS("2015", 10),
69 WINDOWS("2016", 10_RS1),
70 WINDOWS("2017", 10_RS2),
71 WINDOWS("2017.2", 10_RS3),
72 WINDOWS("2018", 10_RS4),
73 WINDOWS("2018.2", 10_RS5),
74 WINDOWS("2019", 10_19H1),
75 WINDOWS("2020", 10_20H1),
76 WINDOWS("2021", 11),
77 WINDOWS("2022", 11_22H2),
78
79 // Feature strings
80 HOST_FEATURE("Module Device", MODULE_DEVICE),
81 HOST_FEATURE("Processor Device", PROCESSOR_DEVICE),
82 HOST_FEATURE("3.0 Thermal Model", 3_0_THERMAL_MODEL),
83 HOST_FEATURE("3.0 _SCP Extensions", 3_0_SCP_EXTENSIONS),
84 HOST_FEATURE("Processor Aggregator Device", PROCESSOR_AGGREGATOR_DEVICE),
85
86 // Interpreter features
87 { .name = "Extended Address Space Descriptor" },
88};
89
91{
93
95
99
100 for (i = 0; i < (UACPI_ARRAY_SIZE(predefined_interfaces) - 1); ++i)
102
103 return UACPI_STATUS_OK;
104}
105
107{
108 struct registered_interface *iface, *next_iface = registered_interfaces;
109
110 while (next_iface) {
111 iface = next_iface;
112 next_iface = iface->next;
113
114 iface->next = UACPI_NULL;
115
116 if (iface->dynamic) {
118 uacpi_free(iface, sizeof(*iface));
119 continue;
120 }
121
122 // Only features are disabled by default
123 iface->disabled = iface->kind == UACPI_INTERFACE_KIND_FEATURE ?
125 }
126
127 if (interface_mutex)
129
134}
135
137{
139}
140
142 const uacpi_char *name
143)
144{
146
147 while (interface) {
148 if (uacpi_strcmp(interface->name, name) == 0)
149 return interface;
150
151 interface = interface->next;
152 }
153
154 return UACPI_NULL;
155}
156
159)
160{
162
163 while (interface) {
164 if (interface->host_type == type)
165 return interface;
166
167 interface = interface->next;
168 }
169
170 return UACPI_NULL;
171}
172
175)
176{
179 uacpi_char *name_copy;
180 uacpi_size name_size;
181
183
186 return ret;
187
188 interface = find_interface_unlocked(name);
189 if (interface != UACPI_NULL) {
190 if (interface->disabled)
191 interface->disabled = UACPI_FALSE;
192
194 goto out;
195 }
196
197 interface = uacpi_kernel_alloc(sizeof(*interface));
200 goto out;
201 }
202
203 name_size = uacpi_strlen(name) + 1;
204 name_copy = uacpi_kernel_alloc(name_size);
205 if (uacpi_unlikely(name_copy == UACPI_NULL)) {
206 uacpi_free(interface, sizeof(*interface));
208 goto out;
209 }
210
211 uacpi_memcpy(name_copy, name, name_size);
212 interface->name = name_copy;
213 interface->weight = 0;
214 interface->kind = kind;
215 interface->host_type = 0;
216 interface->disabled = 0;
217 interface->dynamic = 1;
220
221out:
223 return ret;
224}
225
227{
228 struct registered_interface *cur, *prev;
230
232
235 return ret;
236
238 prev = cur;
239
241 while (cur) {
242 if (uacpi_strcmp(cur->name, name) != 0) {
243 prev = cur;
244 cur = cur->next;
245 continue;
246 }
247
248 if (cur->dynamic) {
249 if (prev == cur) {
251 } else {
252 prev->next = cur->next;
253 }
254
257 uacpi_free(cur, sizeof(*cur));
258 return UACPI_STATUS_OK;
259 }
260
261 /*
262 * If this interface was already disabled, pretend we didn't actually
263 * find it and keep ret as UACPI_STATUS_NOT_FOUND. The fact that it's
264 * still in the registered list is an implementation detail of
265 * predefined interfaces.
266 */
267 if (!cur->disabled) {
268 cur->disabled = UACPI_TRUE;
270 }
271
272 break;
273 }
274
276 return ret;
277}
278
281)
282{
285
287
290 return ret;
291
292 interface = find_host_interface_unlocked(type);
293 if (interface == UACPI_NULL) {
295 goto out;
296 }
297
298 interface->disabled = !enabled;
299out:
301 return ret;
302}
303
305{
307}
308
310{
312}
313
316)
317{
319
321
324 return ret;
325
328 goto out;
329 }
330
332out:
334 return ret;
335}
336
339)
340{
343
345
348 return ret;
349
350 interface = registered_interfaces;
351 while (interface) {
352 if (kind & interface->kind)
354
355 interface = interface->next;
356 }
357
359 return ret;
360}
361
363{
366 uacpi_bool is_supported = UACPI_FALSE;
367
370 return ret;
371
372 interface = find_interface_unlocked(string);
373 if (interface == UACPI_NULL)
374 goto out;
375
378
379 is_supported = !interface->disabled;
381 is_supported = interface_handler(string, is_supported);
382out:
384 *out_value = is_supported;
385 return UACPI_STATUS_OK;
386}
387
388#endif // !UACPI_BAREBONES_MODE
#define interface
Definition: basetyps.h:61
static uacpi_status uacpi_release_native_mutex(uacpi_handle mtx)
Definition: mutex.h:25
static uacpi_status uacpi_acquire_native_mutex(uacpi_handle mtx)
Definition: mutex.h:13
#define uacpi_atomic_load32(ptr)
Definition: atomic.h:104
#define uacpi_atomic_store32(ptr, value)
Definition: atomic.h:109
#define PROCESSOR_DEVICE
Definition: cdrw_hw.h:1147
UINT(* handler)(MSIPACKAGE *)
Definition: action.c:7512
static struct list registered_interfaces
Definition: rpc.c:53
#define UACPI_ENSURE_INIT_LEVEL_AT_LEAST(lvl)
Definition: context.h:127
#define UACPI_ARRAY_SIZE(arr)
Definition: helpers.h:5
uacpi_i32 uacpi_strcmp(const uacpi_char *lhs, const uacpi_char *rhs)
Definition: stdlib.c:96
#define uacpi_memcpy
Definition: stdlib.h:34
#define uacpi_free(mem, _)
Definition: stdlib.h:96
uacpi_size uacpi_strlen(const uacpi_char *str)
Definition: stdlib.c:72
#define uacpi_unlikely(expr)
Definition: compiler.h:58
size_t uacpi_size
Definition: types.h:37
uint32_t uacpi_u32
Definition: types.h:21
bool uacpi_bool
Definition: types.h:31
#define UACPI_FALSE
Definition: types.h:30
char uacpi_char
Definition: types.h:44
#define UACPI_NULL
Definition: types.h:33
uint8_t uacpi_u8
Definition: types.h:19
#define UACPI_TRUE
Definition: types.h:29
#define uacpi_unlikely_error(expr)
Definition: status.h:49
uacpi_status
Definition: status.h:10
@ UACPI_STATUS_NOT_FOUND
Definition: status.h:17
@ UACPI_STATUS_OUT_OF_MEMORY
Definition: status.h:13
@ UACPI_STATUS_ALREADY_EXISTS
Definition: status.h:20
@ UACPI_STATUS_OK
Definition: status.h:11
@ UACPI_INIT_LEVEL_SUBSYSTEM_INITIALIZED
Definition: types.h:66
return ret
Definition: mutex.c:146
action
Definition: namespace.c:707
FxCollectionEntry * cur
GLuint GLuint GLsizei GLenum type
Definition: gl.h:1545
GLenum GLenum GLsizei const GLuint GLboolean enabled
Definition: glext.h:7750
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248
void uacpi_free_dynamic_string(const uacpi_char *str)
Definition: utilities.c:1135
#define _1
Definition: ke_i.h:69
void * uacpi_kernel_alloc(uacpi_size size)
Definition: uacpiosl.c:111
uacpi_handle uacpi_kernel_create_mutex(void)
Definition: uacpiosl.c:139
void uacpi_kernel_free_mutex(uacpi_handle)
Definition: uacpiosl.c:146
void uacpi_deinitialize_interfaces(void)
Definition: osi.c:106
uacpi_status uacpi_handle_osi(const uacpi_char *string, uacpi_bool *out_value)
Definition: osi.c:362
static uacpi_u32 latest_queried_interface
Definition: osi.c:29
#define HOST_FEATURE(string, type)
Definition: osi.c:42
#define WINDOWS(string, interface)
Definition: osi.c:31
uacpi_status uacpi_set_interface_query_handler(uacpi_interface_handler handler)
Definition: osi.c:314
uacpi_status uacpi_disable_host_interface(uacpi_host_interface type)
Definition: osi.c:309
static uacpi_interface_handler interface_handler
Definition: osi.c:28
uacpi_status uacpi_uninstall_interface(const uacpi_char *name)
Definition: osi.c:226
uacpi_status uacpi_initialize_interfaces(void)
Definition: osi.c:90
static struct registered_interface * find_interface_unlocked(const uacpi_char *name)
Definition: osi.c:141
uacpi_status uacpi_install_interface(const uacpi_char *name, uacpi_interface_kind kind)
Definition: osi.c:173
uacpi_vendor_interface uacpi_latest_queried_vendor_interface(void)
Definition: osi.c:136
static uacpi_handle interface_mutex
Definition: osi.c:26
static uacpi_status configure_host_interface(uacpi_host_interface type, uacpi_bool enabled)
Definition: osi.c:279
static struct registered_interface * find_host_interface_unlocked(uacpi_host_interface type)
Definition: osi.c:157
static struct registered_interface predefined_interfaces[]
Definition: osi.c:53
static struct registered_interface * registered_interfaces
Definition: osi.c:27
uacpi_status uacpi_enable_host_interface(uacpi_host_interface type)
Definition: osi.c:304
uacpi_status uacpi_bulk_configure_interfaces(uacpi_interface_action action, uacpi_interface_kind kind)
Definition: osi.c:337
uacpi_host_interface
Definition: osi.h:72
uacpi_interface_kind
Definition: osi.h:52
@ UACPI_INTERFACE_KIND_FEATURE
Definition: osi.h:54
uacpi_bool(* uacpi_interface_handler)(const uacpi_char *name, uacpi_bool supported)
Definition: osi.h:89
uacpi_interface_action
Definition: osi.h:102
@ UACPI_INTERFACE_ACTION_DISABLE
Definition: osi.h:103
uacpi_vendor_interface
Definition: osi.h:12
static unsigned __int64 next
Definition: rand_nt.c:6
struct define * next
Definition: compiler.c:65
char * name
Definition: compiler.c:66
Definition: name.c:39
uacpi_u8 disabled
Definition: osi.c:20
uacpi_u8 kind
Definition: osi.c:14
uacpi_u8 host_type
Definition: osi.c:17
uacpi_u8 dynamic
Definition: osi.c:21
const uacpi_char * name
Definition: osi.c:12
struct registered_interface * next
Definition: osi.c:23
uacpi_u8 weight
Definition: osi.c:13
wchar_t tm const _CrtWcstime_Writes_and_advances_ptr_ count wchar_t ** out
Definition: wcsftime.cpp:383
ActualNumberDriverObjects * sizeof(PDRIVER_OBJECT)) PDRIVER_OBJECT *DriverObjectList