KallistiOS
2.0.0
|
Maple Bus driver interface. More...
Go to the source code of this file.
Data Structures | |
struct | maple_frame |
Maple frame to be queued for transport. More... | |
struct | maple_devinfo |
Maple device info structure. More... | |
struct | maple_response |
Maple response frame structure. More... | |
struct | maple_device |
One maple device. More... | |
struct | maple_port |
Internal representation of a Maple port. More... | |
struct | maple_driver |
A maple device driver. More... | |
struct | maple_state_str |
Maple state structure. More... |
Macros | |
#define | MAPLE_DMA_DEBUG 0 |
Enable Maple DMA debugging. | |
#define | MAPLE_IRQ_DEBUG 0 |
Enable Maple IRQ debugging. | |
#define | MAPLE_BASE 0xa05f6c00 |
Maple register base. | |
#define | MAPLE_DMAADDR (MAPLE_BASE+0x04) |
DMA address register. | |
#define | MAPLE_RESET2 (MAPLE_BASE+0x10) |
Reset register #2. | |
#define | MAPLE_ENABLE (MAPLE_BASE+0x14) |
Enable register. | |
#define | MAPLE_STATE (MAPLE_BASE+0x18) |
Status register. | |
#define | MAPLE_SPEED (MAPLE_BASE+0x80) |
Speed register. | |
#define | MAPLE_RESET1 (MAPLE_BASE+0x8c) |
Reset register #1. | |
#define | MAPLE_RESET2_MAGIC 0 |
2nd reset value | |
#define | MAPLE_ENABLE_ENABLED 1 |
Enable Maple. | |
#define | MAPLE_ENABLE_DISABLED 0 |
Disable Maple. | |
#define | MAPLE_STATE_IDLE 0 |
Idle state. | |
#define | MAPLE_STATE_DMA 1 |
DMA in-progress. | |
#define | MAPLE_SPEED_2MBPS 0 |
2Mbps bus speed | |
#define | MAPLE_SPEED_TIMEOUT(n) ((n) << 16) |
Bus timeout macro. | |
#define | MAPLE_RESET1_MAGIC 0x6155404f |
First reset value. | |
#define | MAPLE_RESPONSE_FILEERR -5 |
File error. | |
#define | MAPLE_RESPONSE_AGAIN -4 |
Try again later. | |
#define | MAPLE_RESPONSE_BADCMD -3 |
Bad command sent. | |
#define | MAPLE_RESPONSE_BADFUNC -2 |
Bad function code. | |
#define | MAPLE_RESPONSE_NONE -1 |
No response. | |
#define | MAPLE_COMMAND_DEVINFO 1 |
Device info request. | |
#define | MAPLE_COMMAND_ALLINFO 2 |
All info request. | |
#define | MAPLE_COMMAND_RESET 3 |
Reset device request. | |
#define | MAPLE_COMMAND_KILL 4 |
Kill device request. | |
#define | MAPLE_RESPONSE_DEVINFO 5 |
Device info response. | |
#define | MAPLE_RESPONSE_ALLINFO 6 |
All info response. | |
#define | MAPLE_RESPONSE_OK 7 |
Command completed ok. | |
#define | MAPLE_RESPONSE_DATATRF 8 |
Data transfer. | |
#define | MAPLE_COMMAND_GETCOND 9 |
Get condition request. | |
#define | MAPLE_COMMAND_GETMINFO 10 |
Get memory information. | |
#define | MAPLE_COMMAND_BREAD 11 |
Block read. | |
#define | MAPLE_COMMAND_BWRITE 12 |
Block write. | |
#define | MAPLE_COMMAND_BSYNC 13 |
Block sync. | |
#define | MAPLE_COMMAND_SETCOND 14 |
Set condition request. | |
#define | MAPLE_COMMAND_MICCONTROL 15 |
Microphone control. | |
#define | MAPLE_COMMAND_CAMCONTROL 17 |
Camera control. | |
#define | MAPLE_FUNC_PURUPURU 0x00010000 |
Jump pack. | |
#define | MAPLE_FUNC_MOUSE 0x00020000 |
Mouse. | |
#define | MAPLE_FUNC_CAMERA 0x00080000 |
Camera (Dreameye) | |
#define | MAPLE_FUNC_CONTROLLER 0x01000000 |
Controller. | |
#define | MAPLE_FUNC_MEMCARD 0x02000000 |
Memory card. | |
#define | MAPLE_FUNC_LCD 0x04000000 |
LCD screen. | |
#define | MAPLE_FUNC_CLOCK 0x08000000 |
Clock. | |
#define | MAPLE_FUNC_MICROPHONE 0x10000000 |
Microphone. | |
#define | MAPLE_FUNC_ARGUN 0x20000000 |
AR gun? | |
#define | MAPLE_FUNC_KEYBOARD 0x40000000 |
Keyboard. | |
#define | MAPLE_FUNC_LIGHTGUN 0x80000000 |
Lightgun. | |
#define | MAPLE_FRAME_VACANT 0 |
Ready to be used. | |
#define | MAPLE_FRAME_UNSENT 1 |
Ready to be sent. | |
#define | MAPLE_FRAME_SENT 2 |
Frame has been sent, but no response yet. | |
#define | MAPLE_FRAME_RESPONDED 3 |
Frame has a response. | |
#define | MAPLE_PORT_COUNT 4 |
Number of ports on the bus. | |
#define | MAPLE_UNIT_COUNT 6 |
Max number of units per port. | |
#define | MAPLE_DMA_SIZE 16384 |
Maple DMA buffer size. | |
#define | maple_read(A) ( *((vuint32*)(A)) ) |
Maple memory read macro. | |
#define | maple_write(A, V) ( *((vuint32*)(A)) = (V) ) |
Maple memory write macro. | |
#define | MAPLE_EOK 0 |
No error. | |
#define | MAPLE_EFAIL -1 |
Command failed. | |
#define | MAPLE_EAGAIN -2 |
Try again later. | |
#define | MAPLE_EINVALID -3 |
Invalid command. | |
#define | MAPLE_ENOTSUPP -4 |
Command not suppoted by device. | |
#define | MAPLE_ETIMEOUT -5 |
Command timed out. | |
#define | MAPLE_FOREACH_BEGIN(TYPE, VARTYPE, VAR) |
Begin a foreach loop over Maple devices. | |
#define | MAPLE_FOREACH_END() |
End a foreach loop over Maple devices. |
Typedefs | |
typedef struct maple_frame | maple_frame_t |
Maple frame to be queued for transport. | |
typedef struct maple_devinfo | maple_devinfo_t |
Maple device info structure. | |
typedef struct maple_response | maple_response_t |
Maple response frame structure. | |
typedef struct maple_device | maple_device_t |
One maple device. | |
typedef struct maple_port | maple_port_t |
Internal representation of a Maple port. | |
typedef struct maple_driver | maple_driver_t |
A maple device driver. | |
typedef struct maple_state_str | maple_state_t |
Maple state structure. |
Functions | |
void | maple_bus_enable () |
Enable the Maple bus. | |
void | maple_bus_disable () |
Disable the Maple bus. | |
void | maple_dma_start () |
Start a Maple DMA. | |
void | maple_dma_stop () |
Stop a Maple DMA. | |
int | maple_dma_in_progress () |
Is a Maple DMA in progress? | |
void | maple_dma_addr (void *ptr) |
Set the Maple DMA address. | |
uint8 | maple_addr (int port, int unit) |
Return a "maple address" for a port, unit pair. | |
void | maple_raddr (uint8 addr, int *port, int *unit) |
Decompose a "maple address" into a port, unit pair. | |
const char * | maple_pcaps (uint32 functions) |
Return a string with the capabilities of a given function code. | |
const char * | maple_perror (int response) |
Return a string representing the maple response code. | |
int | maple_dev_valid (int p, int u) |
Determine if a given device is valid. | |
void | maple_queue_flush () |
Send all queued frames. | |
int | maple_queue_frame (maple_frame_t *frame) |
Submit a frame for queueing. | |
int | maple_queue_remove (maple_frame_t *frame) |
Remove a used frame from the queue. | |
void | maple_frame_init (maple_frame_t *frame) |
Initialize a new frame to prepare it to be placed on the queue. | |
int | maple_frame_lock (maple_frame_t *frame) |
Lock a frame so that someone else can't use it in the mean time. | |
void | maple_frame_unlock (maple_frame_t *frame) |
Unlock a frame. | |
int | maple_driver_reg (maple_driver_t *driver) |
Register a maple device driver. | |
int | maple_driver_unreg (maple_driver_t *driver) |
Unregister a maple device driver. | |
int | maple_driver_attach (maple_frame_t *det) |
Attach a maple device to a driver, if possible. | |
int | maple_driver_detach (int p, int u) |
Detach an attached maple device. | |
int | maple_driver_foreach (maple_driver_t *drv, int(*callback)(maple_device_t *)) |
For each device which the given driver controls, call the callback. | |
void | maple_vbl_irq_hnd (uint32 code) |
Called on every VBL (~60fps). | |
void | maple_dma_irq_hnd (uint32 code) |
Called after a Maple DMA send / receive pair completes. | |
int | maple_enum_count () |
Return the number of connected devices. | |
maple_device_t * | maple_enum_dev (int p, int u) |
Get a raw device info struct for the given device. | |
maple_device_t * | maple_enum_type (int n, uint32 func) |
Get the Nth device of the requested type (where N is zero-indexed). | |
maple_device_t * | maple_enum_type_ex (int n, uint32 func, uint32 cap) |
Return the Nth device that is of the requested type and supports the list of capabilities given. | |
void * | maple_dev_status (maple_device_t *dev) |
Get the status struct for the requested maple device. | |
int | maple_init () |
Initialize Maple. | |
void | maple_shutdown () |
Shutdown Maple. | |
void | maple_wait_scan () |
Wait for the initial bus scan to complete. |
Variables | |
maple_state_t | maple_state |
Global state info. |
Maple Bus driver interface.
This file provides support for accessing the Maple bus on the Dreamcast. Maple is the bus that all of your controllers and memory cards and the like connect to, so this is one of those types of things that are quite important to know how to use.
Each peripheral device registers their driver within this system, and can be accessed through the functions here. Most of the drivers have their own functionality that is implemented in their header files, as well.
#define MAPLE_DMA_DEBUG 0 |
Enable Maple DMA debugging.
Changing this to a 1 will add massive amounts of processing time to the maple system in general, but it can help in verifying DMA errors. In general, for most purposes this should stay disabled.
#define MAPLE_DMA_SIZE 16384 |
Maple DMA buffer size.
Increase if you do a LOT of maple stuff on every periodic interrupt.
#define MAPLE_FOREACH_BEGIN | ( | TYPE, | |
VARTYPE, | |||
VAR | |||
) |
Begin a foreach loop over Maple devices.
This macro (along with the MAPLE_FOREACH_END() one) implements a simple foreach-style loop over the given type of devices. Essentially, it grabs the status of the device, and leaves it to you to figure out what to do with it.
The most common use of this would be to look for input on any controller.
TYPE | The function code of devices to look at. |
VARTYPE | The type to cast the return value of maple_dev_status() to. |
VAR | The name of the result of maple_dev_status(). |
#define MAPLE_FOREACH_END | ( | ) |
End a foreach loop over Maple devices.
Each MAPLE_FOREACH_BEGIN() must be paired with one of these after the loop body.
#define MAPLE_IRQ_DEBUG 0 |
Enable Maple IRQ debugging.
Changing this to a 1 will turn on intra-interrupt debugging messages, which may cause issues if you're using dcload rather than a raw serial debug terminal. You probably will never have a good reason to enable this, so keep it disabled for normal use.
#define MAPLE_PORT_COUNT 4 |
Number of ports on the bus.
#define maple_read | ( | A | ) | ( *((vuint32*)(A)) ) |
Maple memory read macro.
#define MAPLE_UNIT_COUNT 6 |
Max number of units per port.
#define maple_write | ( | A, | |
V | |||
) | ( *((vuint32*)(A)) = (V) ) |
Maple memory write macro.
typedef struct maple_device maple_device_t |
One maple device.
Note that we duplicate the port/unit info which is normally somewhat implicit so that we can pass around a pointer to a particular device struct.
typedef struct maple_devinfo maple_devinfo_t |
Maple device info structure.
This structure is used by the hardware to deliver the response to the device info request.
typedef struct maple_driver maple_driver_t |
A maple device driver.
Anything which is added to this list is capable of handling one or more maple device types. When a device of the given type is connected (includes startup "connection"), the driver is invoked. This same process happens for disconnection, response receipt, and on a periodic interval (for normal updates).
typedef struct maple_frame maple_frame_t |
Maple frame to be queued for transport.
Internal representation of a frame to be queued up for sending.
typedef struct maple_port maple_port_t |
Internal representation of a Maple port.
each maple port can contain up to 6 devices, the first one of which is always the port itself.
typedef struct maple_response maple_response_t |
Maple response frame structure.
This structure is used to deliver the actual response to a request placed. The data field is where all the interesting stuff will be.
typedef struct maple_state_str maple_state_t |
Maple state structure.
We put everything in here to keep from polluting the global namespace too much.
uint8 maple_addr | ( | int | port, |
int | unit | ||
) |
Return a "maple address" for a port, unit pair.
port | The port to build the address for. |
unit | The unit to build the address for. |
void maple_bus_disable | ( | ) |
Disable the Maple bus.
There's really not many good reasons to be mucking with this at runtime.
void maple_bus_enable | ( | ) |
Enable the Maple bus.
This will be done for you autmatically at init time, and there's probably not many reasons to be doing this during runtime.
void* maple_dev_status | ( | maple_device_t * | dev | ) |
Get the status struct for the requested maple device.
This function will wait until the status is valid before returning. You should cast to the appropriate type you're expecting.
dev | The device to look up. |
int maple_dev_valid | ( | int | p, |
int | u | ||
) |
Determine if a given device is valid.
p | The port to check. |
u | The unit to check. |
void maple_dma_addr | ( | void * | ptr | ) |
Set the Maple DMA address.
Once again, you should not muck around with this in your programs.
int maple_dma_in_progress | ( | ) |
Is a Maple DMA in progress?
void maple_dma_irq_hnd | ( | uint32 | code | ) |
Called after a Maple DMA send / receive pair completes.
code | The ASIC event code. |
void maple_dma_start | ( | ) |
Start a Maple DMA.
This stuff will all be handled internally, so there's probably no reason to be doing this yourself.
void maple_dma_stop | ( | ) |
Stop a Maple DMA.
This stuff will all be handled internally, so there's probably no reason to be doing this yourself.
int maple_driver_attach | ( | maple_frame_t * | det | ) |
Attach a maple device to a driver, if possible.
det | The detection frame. |
0 | On success. |
-1 | If no driver is available. |
int maple_driver_detach | ( | int | p, |
int | u | ||
) |
Detach an attached maple device.
p | The port of the device to detach. |
u | The unit of the device to detach. |
0 | On success. |
-1 | If the device wasn't valid. |
int maple_driver_foreach | ( | maple_driver_t * | drv, |
int(*)(maple_device_t *) | callback | ||
) |
For each device which the given driver controls, call the callback.
drv | The driver to loop through devices of. |
callback | The function to call. The parameter is the device that it is being called on. It should return 0 on success, and <0 on failure. |
0 | On success. |
-1 | If any callbacks return <0. |
int maple_driver_reg | ( | maple_driver_t * | driver | ) |
Register a maple device driver.
This should be done before calling maple_init().
0 | On success (no error conditions defined). |
int maple_driver_unreg | ( | maple_driver_t * | driver | ) |
Unregister a maple device driver.
0 | On success (no error conditions defined). |
int maple_enum_count | ( | ) |
Return the number of connected devices.
maple_device_t* maple_enum_dev | ( | int | p, |
int | u | ||
) |
Get a raw device info struct for the given device.
p | The port to look up. |
u | The unit to look up. |
maple_device_t* maple_enum_type | ( | int | n, |
uint32 | func | ||
) |
Get the Nth device of the requested type (where N is zero-indexed).
n | The index to look up. |
func | The function code to look for. |
maple_device_t* maple_enum_type_ex | ( | int | n, |
uint32 | func, | ||
uint32 | cap | ||
) |
Return the Nth device that is of the requested type and supports the list of capabilities given.
Note, this only currently makes sense for controllers, since some devices don't necessarily use the function data in the same manner that controllers do (and controllers are the only devices where we have a list of what all the bits mean at the moment).
n | The index to look up. |
func | The function code to look for. |
cap | Capabilities bits to look for. |
void maple_frame_init | ( | maple_frame_t * | frame | ) |
Initialize a new frame to prepare it to be placed on the queue.
You should call this before you fill in the frame data.
frame | The frame to initialize. |
int maple_frame_lock | ( | maple_frame_t * | frame | ) |
Lock a frame so that someone else can't use it in the mean time.
0 | On success. |
-1 | If the frame is already locked. |
void maple_frame_unlock | ( | maple_frame_t * | frame | ) |
Unlock a frame.
int maple_init | ( | ) |
Initialize Maple.
const char* maple_pcaps | ( | uint32 | functions | ) |
Return a string with the capabilities of a given function code.
This function is not re-entrant, and thus NOT THREAD SAFE.
functions | The list of function codes. |
const char* maple_perror | ( | int | response | ) |
Return a string representing the maple response code.
response | The response code returned from the function. |
void maple_queue_flush | ( | ) |
Send all queued frames.
int maple_queue_frame | ( | maple_frame_t * | frame | ) |
Submit a frame for queueing.
This will generally be called inside the periodic interrupt; however, if you need to do something asynchronously (e.g., VMU access) then it might cause some problems. In this case, the function will automatically do locking by disabling interrupts temporarily. In any case, the callback will be done inside an IRQ context.
frame | The frame to queue up. |
0 | On success. |
-1 | If the frame is already queued. |
int maple_queue_remove | ( | maple_frame_t * | frame | ) |
Remove a used frame from the queue.
This will be done automatically when the frame is consumed.
frame | The frame to remove from the queue. |
0 | On success. |
-1 | If the frame is not queued. |
void maple_raddr | ( | uint8 | addr, |
int * | port, | ||
int * | unit | ||
) |
Decompose a "maple address" into a port, unit pair.
WARNING: This function will not work with multi-cast addresses!
addr | The input address. |
port | Output space for the port of the address. |
unit | Output space for the unit of the address. |
void maple_shutdown | ( | ) |
Shutdown Maple.
void maple_vbl_irq_hnd | ( | uint32 | code | ) |
Called on every VBL (~60fps).
code | The ASIC event code. |
void maple_wait_scan | ( | ) |
Wait for the initial bus scan to complete.
maple_state_t maple_state |
Global state info.
Do not manipulate this state yourself, as it will likely break things if you do so.