ReactOS 0.4.16-dev-1946-g52006dd
osi.c File Reference
Include dependency graph for osi.c:

Go to the source code of this file.

Classes

struct  registered_interface
 

Macros

#define WINDOWS(string, interface)
 
#define HOST_FEATURE(string, type)
 

Functions

uacpi_status uacpi_initialize_interfaces (void)
 
void uacpi_deinitialize_interfaces (void)
 
uacpi_vendor_interface uacpi_latest_queried_vendor_interface (void)
 
static struct registered_interfacefind_interface_unlocked (const uacpi_char *name)
 
static struct registered_interfacefind_host_interface_unlocked (uacpi_host_interface type)
 
uacpi_status uacpi_install_interface (const uacpi_char *name, uacpi_interface_kind kind)
 
uacpi_status uacpi_uninstall_interface (const uacpi_char *name)
 
static uacpi_status configure_host_interface (uacpi_host_interface type, uacpi_bool enabled)
 
uacpi_status uacpi_enable_host_interface (uacpi_host_interface type)
 
uacpi_status uacpi_disable_host_interface (uacpi_host_interface type)
 
uacpi_status uacpi_set_interface_query_handler (uacpi_interface_handler handler)
 
uacpi_status uacpi_bulk_configure_interfaces (uacpi_interface_action action, uacpi_interface_kind kind)
 
uacpi_status uacpi_handle_osi (const uacpi_char *string, uacpi_bool *out_value)
 

Variables

static uacpi_handle interface_mutex
 
static struct registered_interfaceregistered_interfaces
 
static uacpi_interface_handler interface_handler
 
static uacpi_u32 latest_queried_interface
 
static struct registered_interface predefined_interfaces []
 

Macro Definition Documentation

◆ HOST_FEATURE

#define HOST_FEATURE (   string,
  type 
)
Value:
{ \
.name = string, \
.weight = 0, \
.host_type = UACPI_HOST_INTERFACE_##type, \
.disabled = 1, \
.dynamic = 0, \
.next = UACPI_NULL, \
}
#define UACPI_NULL
Definition: types.h:33
GLuint GLuint GLsizei GLenum type
Definition: gl.h:1545
char string[160]
Definition: util.h:11
@ UACPI_INTERFACE_KIND_FEATURE
Definition: osi.h:54

Definition at line 42 of file osi.c.

◆ WINDOWS

#define WINDOWS (   string,
  interface 
)
Value:
{ \
.name = "Windows "string, \
.weight = UACPI_VENDOR_INTERFACE_WINDOWS_##interface, \
.host_type = 0, \
.disabled = 0, \
.dynamic = 0, \
.next = UACPI_NULL \
}
#define interface
Definition: basetyps.h:61
@ UACPI_INTERFACE_KIND_VENDOR
Definition: osi.h:53

Definition at line 31 of file osi.c.

Function Documentation

◆ configure_host_interface()

static uacpi_status configure_host_interface ( uacpi_host_interface  type,
uacpi_bool  enabled 
)
static

Definition at line 279 of file osi.c.

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}
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_ENSURE_INIT_LEVEL_AT_LEAST(lvl)
Definition: context.h:127
#define uacpi_unlikely_error(expr)
Definition: status.h:49
uacpi_status
Definition: status.h:10
@ UACPI_STATUS_NOT_FOUND
Definition: status.h:17
@ UACPI_INIT_LEVEL_SUBSYSTEM_INITIALIZED
Definition: types.h:66
return ret
Definition: mutex.c:146
GLenum GLenum GLsizei const GLuint GLboolean enabled
Definition: glext.h:7750
static uacpi_handle interface_mutex
Definition: osi.c:26
wchar_t tm const _CrtWcstime_Writes_and_advances_ptr_ count wchar_t ** out
Definition: wcsftime.cpp:383

Referenced by uacpi_disable_host_interface(), and uacpi_enable_host_interface().

◆ find_host_interface_unlocked()

static struct registered_interface * find_host_interface_unlocked ( uacpi_host_interface  type)
static

Definition at line 157 of file osi.c.

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}
static struct registered_interface * registered_interfaces
Definition: osi.c:27
static unsigned __int64 next
Definition: rand_nt.c:6

◆ find_interface_unlocked()

static struct registered_interface * find_interface_unlocked ( const uacpi_char name)
static

Definition at line 141 of file osi.c.

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}
uacpi_i32 uacpi_strcmp(const uacpi_char *lhs, const uacpi_char *rhs)
Definition: stdlib.c:96
char * name
Definition: compiler.c:66
Definition: name.c:39

◆ uacpi_bulk_configure_interfaces()

uacpi_status uacpi_bulk_configure_interfaces ( uacpi_interface_action  action,
uacpi_interface_kind  kind 
)

Definition at line 337 of file osi.c.

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}
action
Definition: namespace.c:707
@ UACPI_INTERFACE_ACTION_DISABLE
Definition: osi.h:103

◆ uacpi_deinitialize_interfaces()

void uacpi_deinitialize_interfaces ( void  )

Definition at line 106 of file osi.c.

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}
#define uacpi_free(mem, _)
Definition: stdlib.h:96
#define UACPI_FALSE
Definition: types.h:30
#define UACPI_TRUE
Definition: types.h:29
void uacpi_free_dynamic_string(const uacpi_char *str)
Definition: utilities.c:1135
void uacpi_kernel_free_mutex(uacpi_handle)
Definition: uacpiosl.c:146
static uacpi_u32 latest_queried_interface
Definition: osi.c:29
static uacpi_interface_handler interface_handler
Definition: osi.c:28
uacpi_u8 disabled
Definition: osi.c:20
uacpi_u8 kind
Definition: osi.c:14
uacpi_u8 dynamic
Definition: osi.c:21
const uacpi_char * name
Definition: osi.c:12
struct registered_interface * next
Definition: osi.c:23

Referenced by uacpi_state_reset().

◆ uacpi_disable_host_interface()

uacpi_status uacpi_disable_host_interface ( uacpi_host_interface  type)

Definition at line 309 of file osi.c.

310{
312}
static uacpi_status configure_host_interface(uacpi_host_interface type, uacpi_bool enabled)
Definition: osi.c:279

◆ uacpi_enable_host_interface()

uacpi_status uacpi_enable_host_interface ( uacpi_host_interface  type)

Definition at line 304 of file osi.c.

305{
307}

◆ uacpi_handle_osi()

uacpi_status uacpi_handle_osi ( const uacpi_char string,
uacpi_bool out_value 
)

Definition at line 362 of file osi.c.

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}
#define uacpi_atomic_store32(ptr, value)
Definition: atomic.h:109
bool uacpi_bool
Definition: types.h:31
@ UACPI_STATUS_OK
Definition: status.h:11

Referenced by uacpi_osi().

◆ uacpi_initialize_interfaces()

uacpi_status uacpi_initialize_interfaces ( void  )

Definition at line 90 of file osi.c.

91{
93
95
99
100 for (i = 0; i < (UACPI_ARRAY_SIZE(predefined_interfaces) - 1); ++i)
102
103 return UACPI_STATUS_OK;
104}
#define UACPI_ARRAY_SIZE(arr)
Definition: helpers.h:5
#define uacpi_unlikely(expr)
Definition: compiler.h:58
size_t uacpi_size
Definition: types.h:37
@ UACPI_STATUS_OUT_OF_MEMORY
Definition: status.h:13
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
uacpi_handle uacpi_kernel_create_mutex(void)
Definition: uacpiosl.c:139
static struct registered_interface predefined_interfaces[]
Definition: osi.c:53

Referenced by uacpi_initialize().

◆ uacpi_install_interface()

uacpi_status uacpi_install_interface ( const uacpi_char name,
uacpi_interface_kind  kind 
)

Definition at line 173 of file osi.c.

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}
static struct list registered_interfaces
Definition: rpc.c:53
#define uacpi_memcpy
Definition: stdlib.h:34
uacpi_size uacpi_strlen(const uacpi_char *str)
Definition: stdlib.c:72
char uacpi_char
Definition: types.h:44
@ UACPI_STATUS_ALREADY_EXISTS
Definition: status.h:20
void * uacpi_kernel_alloc(uacpi_size size)
Definition: uacpiosl.c:111
struct define * next
Definition: compiler.c:65
ActualNumberDriverObjects * sizeof(PDRIVER_OBJECT)) PDRIVER_OBJECT *DriverObjectList

◆ uacpi_latest_queried_vendor_interface()

uacpi_vendor_interface uacpi_latest_queried_vendor_interface ( void  )

Definition at line 136 of file osi.c.

137{
139}
#define uacpi_atomic_load32(ptr)
Definition: atomic.h:104

◆ uacpi_set_interface_query_handler()

uacpi_status uacpi_set_interface_query_handler ( uacpi_interface_handler  handler)

Definition at line 314 of file osi.c.

◆ uacpi_uninstall_interface()

uacpi_status uacpi_uninstall_interface ( const uacpi_char name)

Definition at line 226 of file osi.c.

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}
FxCollectionEntry * cur

Variable Documentation

◆ interface_handler

uacpi_interface_handler interface_handler
static

◆ interface_mutex

◆ latest_queried_interface

uacpi_u32 latest_queried_interface
static

◆ predefined_interfaces

struct registered_interface predefined_interfaces[]
static

Definition at line 53 of file osi.c.

Referenced by uacpi_initialize_interfaces().

◆ registered_interfaces