src/gba/hardware.h (view raw)
1/* Copyright (c) 2013-2015 Jeffrey Pfau
2 *
3 * This Source Code Form is subject to the terms of the Mozilla Public
4 * License, v. 2.0. If a copy of the MPL was not distributed with this
5 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
6#ifndef GBA_HARDWARE_H
7#define GBA_HARDWARE_H
8
9#include "util/common.h"
10
11#include "macros.h"
12
13#define IS_GPIO_REGISTER(reg) ((reg) == GPIO_REG_DATA || (reg) == GPIO_REG_DIRECTION || (reg) == GPIO_REG_CONTROL)
14
15struct GBARotationSource {
16 void (*sample)(struct GBARotationSource*);
17
18 int32_t (*readTiltX)(struct GBARotationSource*);
19 int32_t (*readTiltY)(struct GBARotationSource*);
20
21 int32_t (*readGyroZ)(struct GBARotationSource*);
22};
23
24struct GBALuminanceSource {
25 void (*sample)(struct GBALuminanceSource*);
26
27 uint8_t (*readLuminance)(struct GBALuminanceSource*);
28};
29
30struct GBARTCSource {
31 void (*sample)(struct GBARTCSource*);
32
33 time_t (*unixTime)(struct GBARTCSource*);
34};
35
36enum GBAHardwareDevice {
37 HW_NO_OVERRIDE = 0x8000,
38 HW_NONE = 0,
39 HW_RTC = 1,
40 HW_RUMBLE = 2,
41 HW_LIGHT_SENSOR = 4,
42 HW_GYRO = 8,
43 HW_TILT = 16
44};
45
46enum GPIORegister {
47 GPIO_REG_DATA = 0xC4,
48 GPIO_REG_DIRECTION = 0xC6,
49 GPIO_REG_CONTROL = 0xC8
50};
51
52enum GPIODirection {
53 GPIO_WRITE_ONLY = 0,
54 GPIO_READ_WRITE = 1
55};
56
57DECL_BITFIELD(RTCControl, uint8_t);
58DECL_BIT(RTCControl, MinIRQ, 3);
59DECL_BIT(RTCControl, Hour24, 6);
60DECL_BIT(RTCControl, Poweroff, 7);
61
62enum RTCCommand {
63 RTC_RESET = 0,
64 RTC_DATETIME = 2,
65 RTC_FORCE_IRQ = 3,
66 RTC_CONTROL = 4,
67 RTC_TIME = 6
68};
69
70DECL_BITFIELD(RTCCommandData, uint8_t);
71DECL_BITS(RTCCommandData, Magic, 0, 4);
72DECL_BITS(RTCCommandData, Command, 4, 3);
73DECL_BIT(RTCCommandData, Reading, 7);
74
75struct GBARTC {
76 int bytesRemaining;
77 int transferStep;
78 int bitsRead;
79 int bits;
80 int commandActive;
81 RTCCommandData command;
82 RTCControl control;
83 uint8_t time[7];
84} __attribute__((packed));
85
86struct GBARumble {
87 void (*setRumble)(struct GBARumble*, int enable);
88};
89
90DECL_BITFIELD(GPIOPin, uint16_t);
91
92struct GBACartridgeHardware {
93 struct GBA* p;
94 int devices;
95 enum GPIODirection readWrite;
96 uint16_t* gpioBase;
97
98 uint16_t pinState;
99 uint16_t direction;
100
101 struct GBARTC rtc;
102
103 uint16_t gyroSample;
104 bool gyroEdge;
105
106 unsigned lightCounter : 12;
107 uint8_t lightSample;
108 bool lightEdge;
109
110 uint16_t tiltX;
111 uint16_t tiltY;
112 int tiltState;
113};
114
115void GBAHardwareInit(struct GBACartridgeHardware* gpio, uint16_t* gpioBase);
116void GBAHardwareClear(struct GBACartridgeHardware* gpio);
117
118void GBAHardwareInitRTC(struct GBACartridgeHardware* gpio);
119void GBAHardwareInitGyro(struct GBACartridgeHardware* gpio);
120void GBAHardwareInitRumble(struct GBACartridgeHardware* gpio);
121void GBAHardwareInitLight(struct GBACartridgeHardware* gpio);
122void GBAHardwareInitTilt(struct GBACartridgeHardware* gpio);
123
124void GBAHardwareGPIOWrite(struct GBACartridgeHardware* gpio, uint32_t address, uint16_t value);
125void GBAHardwareTiltWrite(struct GBACartridgeHardware* gpio, uint32_t address, uint8_t value);
126uint8_t GBAHardwareTiltRead(struct GBACartridgeHardware* gpio, uint32_t address);
127
128struct GBASerializedState;
129void GBAHardwareSerialize(const struct GBACartridgeHardware* gpio, struct GBASerializedState* state);
130void GBAHardwareDeserialize(struct GBACartridgeHardware* gpio, const struct GBASerializedState* state);
131
132#endif