aboutsummaryrefslogtreecommitdiff
path: root/sys/dev/acpi_support/acpi_wmi_if.m
blob: b2d5f39ba5d3c0a75f0bab4246f64853b89f9cbb (plain) (blame)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
#-
# Copyright (c) 2009 Michael Gmelin
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
#    notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
#    notice, this list of conditions and the following disclaimer in the
#    documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
# SUCH DAMAGE.
#
# $FreeBSD: src/sys/dev/acpi_support/acpi_wmi_if.m,v 1.2.2.1.6.1 2010/12/21 17:09:25 kensmith Exp $
#

#include <sys/bus.h>
#include <sys/types.h>
#include <contrib/dev/acpica/include/acpi.h>

INTERFACE acpi_wmi;

#
# Default implementation for acpi_wmi_generic_provides_guid_string().
#
CODE {
	static int
	acpi_wmi_generic_provides_guid_string(device_t dev, const char* guid_string)
	{
		return 0;
	}
};


#
# Check if given GUID exists in WMI
# Returns number of instances (max_instace+1) or 0 if guid doesn't exist
#
# device_t dev:	Device to probe
# const char* guid_string: String form of the GUID
#
METHOD int provides_guid_string {
	device_t	dev;
	const char*	guid_string;
} DEFAULT acpi_wmi_generic_provides_guid_string;

#
# Evaluate a WMI method call
#
# device_t dev:  Device to use
# const char* guid_string:  String form of the GUID
# UINT8 instance: instance id
# UINT32 method_id: method to call
# const ACPI_BUFFER* in: input data
# ACPI_BUFFER* out: output buffer
#
METHOD ACPI_STATUS evaluate_call {
	device_t	dev;
	const char	*guid_string;
	UINT8		instance;
	UINT32		method_id;
	const ACPI_BUFFER *in;
	ACPI_BUFFER	*out;
};

#
# Get content of a WMI block
#
# device_t dev:  Device to use
# const char* guid_string:  String form of the GUID
# UINT8 instance: instance id
# ACPI_BUFFER* out: output buffer
#
METHOD ACPI_STATUS get_block {
	device_t	dev;
	const char	*guid_string;
	UINT8		instance;
	ACPI_BUFFER	*out;
};
#
# Write to a WMI data block
#
# device_t dev:  Device to use
# const char* guid_string:  String form of the GUID
# UINT8 instance: instance id
# const ACPI_BUFFER* in: input data
#
METHOD ACPI_STATUS set_block {
	device_t	dev;
	const char	*guid_string;
	UINT8		instance;
	const ACPI_BUFFER *in;
};

#
# Install wmi event handler
#
# device_t dev:  Device to use
# const char* guid_string:  String form of the GUID
# ACPI_NOTIFY_HANDLER handler: Handler
# void* data: Payload
#
METHOD ACPI_STATUS install_event_handler {
	device_t	dev;
	const char	*guid_string;
	ACPI_NOTIFY_HANDLER handler;
	void		*data;
};

#
# Remove wmi event handler
#
# device_t dev:  Device to use
# const char* guid_string:  String form of the GUID
#
METHOD ACPI_STATUS remove_event_handler {
	device_t	dev;
	const char	*guid_string;
};


#
# Get event data associated to an event
#
# device_t dev:  Device to use
# UINT32 event_id: event id
# ACPI_BUFFER* out: output buffer
#
METHOD ACPI_STATUS get_event_data {
	device_t	dev;
	UINT32		event_id;
	ACPI_BUFFER	*out;
};