Necessarily, this means that dma_start must now know what the size of the response is, so that it can issue the appropriate number of ocbp instructions. This also cleans up the inconsistent _command_buf and _recieve_buf declarations.
36 lines
1.0 KiB
C++
36 lines
1.0 KiB
C++
#include "align.hpp"
|
|
|
|
#include "maple/maple.hpp"
|
|
#include "maple/maple_impl.hpp"
|
|
#include "maple/maple_bus_commands.hpp"
|
|
#include "sh7091/serial.hpp"
|
|
|
|
uint32_t _command_buf[(1024 + 32) / 4];
|
|
uint32_t _receive_buf[(1024 + 32) / 4];
|
|
|
|
void main()
|
|
{
|
|
uint32_t * command_buf = align_32byte(_command_buf);
|
|
uint32_t * receive_buf = align_32byte(_receive_buf);
|
|
|
|
using command_type = device_request;
|
|
using response_type = device_status;
|
|
|
|
uint32_t size = maple::init_host_command_all_ports<command_type, response_type>(command_buf, receive_buf);
|
|
maple::dma_start(command_buf, size);
|
|
|
|
uint8_t * buf = reinterpret_cast<uint8_t *>(receive_buf);
|
|
for (uint8_t port = 0; port < 4; port++) {
|
|
serial::string("port ");
|
|
serial::integer<uint8_t>(port);
|
|
|
|
constexpr uint32_t command_response_size = (sizeof (maple::command_response<response_type::data_fields>));
|
|
for (uint32_t i = 0; i < command_response_size; i++) {
|
|
serial::integer<uint8_t>(buf[port * command_response_size + i]);
|
|
}
|
|
serial::character('\n');
|
|
}
|
|
|
|
while (1);
|
|
}
|