This repository has been archived by the owner on Jan 18, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpinput.lua
196 lines (154 loc) · 2.96 KB
/
pinput.lua
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
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
-- pinput client v0.1.4
-- common
pi_gpio = 0x5f80
pi_magic = {
0x46c7.2002,
0x6e44.ab77,
0xd67f.dcbe,
0x4d98.77d2,
}
pi_num_players = 8
pi_gamepad_stride = 16
-- write pinput magic to gpio
function pi_init()
for i = 1, #pi_magic do
poke4(
pi_gpio + 4 * (i - 1),
pi_magic[i]
)
end
end
-- if magic is cleared,
-- pinput is ready
function pi_is_inited()
return peek4(pi_gpio) ~= pi_magic[1]
end
-- buttons
pi_buttons_offset = 2
pi_num_buttons = 16
pi_⬆️ = 0
pi_⬇️ = 1
pi_⬅️ = 2
pi_➡️ = 3
pi_start = 4
pi_back = 5
pi_ls = 6
pi_rs = 7
pi_lb = 8
pi_rb = 9
pi_guide = 10
pi_misc = 11
pi_a = 12
pi_🅾️ = pi_a
pi_b = 13
pi_❎ = pi_b
pi_x = 14
pi_y = 15
-- read a button
function pi_btn(b, pl)
pl = pl or 0
if pl < 0 or pl >= pi_num_players
or b < 0 or b >= pi_num_buttons then
assert(false, 'pi_btn: parameter out of range')
end
local buttons = peek2(pi_gpio
+ pl * pi_gamepad_stride
+ pi_buttons_offset)
return 1 & (buttons >> b) == 1
end
-- triggers
pi_trigger_offset = 4
pi_trigger_stride = 1
pi_lt = 0
pi_rt = 1
pi_num_triggers = 2
-- read a trigger
function pi_trigger(t, pl)
pl = pl or 0
if pl < 0 or pl >= pi_num_players
or t < 0 or t >= pi_num_triggers then
assert(false, 'pi_trigger: parameter out of range')
end
return peek(pi_gpio
+ pl * pi_gamepad_stride
+ pi_trigger_offset
+ t * pi_trigger_stride)
end
-- sticks
pi_axis_offset = 6
pi_axis_stride = 2
pi_num_axes = 4
pi_lx = 0
pi_ly = 1
pi_rx = 2
pi_ry = 3
function pi_axis(a, pl)
pl = pl or 0
if pl < 0 or pl >= pi_num_players
or a < 0 or a >= pi_num_axes then
assert(false, 'pi_axis: parameter out of range')
end
return peek2(pi_gpio
+ pl * pi_gamepad_stride
+ pi_axis_offset
+ a * pi_axis_stride)
end
-- rumble
pi_rumble_offset = 14
pi_rumble_stride = 1
pi_num_rumbles = 2
pi_lo = 0
pi_hi = 1
-- note: this writes rumble,
-- instead of reading it
function pi_rumble(r, v, pl)
pl = pl or 0
if pl < 0 or pl >= pi_num_players
or r < 0 or r >= pi_num_rumbles
or v < 0x00 or v > 0xff
or v % 1 ~= 0 then
assert(false, 'pi_rumble: parameter out of range')
end
poke(pi_gpio
+ pl * pi_gamepad_stride
+ pi_rumble_offset
+ r * pi_rumble_stride,
v
)
end
-- flags
pi_flags_offset = 0
pi_num_flags = 7
pi_connected = 0
pi_has_battery = 1
pi_charging = 2
pi_has_guide_button = 3
pi_has_misc_button = 4
pi_has_rumble = 5
pi_haptic_device = 6
-- read a flag
function pi_flag(f, pl)
pl = pl or 0
if pl < 0 or pl >= pi_num_players
or f < 0 or f >= pi_num_flags then
assert(false, 'pi_flag: parameter out of range')
end
local buttons = peek2(pi_gpio
+ pl * pi_gamepad_stride
+ pi_flags_offset)
return 1 & (buttons >> f) == 1
end
-- battery level
pi_battery_offset = 1
-- read battery level
-- (0 for wired)
function pi_battery(pl)
pl = pl or 0
if pl < 0 or pl >= pi_num_players then
assert(false, 'pi_battery: parameter out of range')
end
return peek(pi_gpio
+ pl * pi_gamepad_stride
+ pi_battery_offset)
end