acadia/sys/denali/denali_server.cpp

64 lines
1.8 KiB
C++
Raw Normal View History

2023-06-15 16:20:29 -07:00
#include "denali_server.h"
#include <glacier/memory/move.h>
2023-06-21 18:28:54 -07:00
#include <glacier/status/error.h>
2023-06-15 16:20:29 -07:00
#include <mammoth/debug.h>
#include <zcall.h>
namespace {
DenaliServer* gServer = nullptr;
void HandleResponse(ResponseContext& response, uint64_t lba, uint64_t size,
2023-06-21 23:14:42 -07:00
z_cap_t mem) {
gServer->HandleResponse(response, lba, size, mem);
}
} // namespace
glcr::ErrorOr<glcr::UniquePtr<DenaliServer>> DenaliServer::Create(
AhciDriver& driver) {
z_cap_t cap;
RET_ERR(ZEndpointCreate(&cap));
return glcr::UniquePtr<DenaliServer>(new DenaliServer(cap, driver));
}
2023-06-15 16:20:29 -07:00
glcr::ErrorCode DenaliServer::HandleRequest(RequestContext& request,
ResponseContext& response) {
switch (request.request_id()) {
case DENALI_READ: {
DenaliReadRequest* req = 0;
glcr::ErrorCode err = request.As<DenaliReadRequest>(&req);
if (err != glcr::OK) {
response.WriteError(err);
}
err = HandleRead(req, response);
if (err != glcr::OK) {
response.WriteError(err);
2023-06-15 16:20:29 -07:00
}
break;
2023-06-15 16:20:29 -07:00
}
default:
response.WriteError(glcr::UNIMPLEMENTED);
break;
2023-06-15 16:20:29 -07:00
}
return glcr::OK;
2023-06-15 16:20:29 -07:00
}
glcr::ErrorCode DenaliServer::HandleRead(DenaliReadRequest* request,
ResponseContext& context) {
ASSIGN_OR_RETURN(AhciDevice * device, driver_.GetDevice(request->device_id));
device->IssueCommand(new DmaReadCommand(request->lba, request->size,
::HandleResponse, context));
2023-06-15 16:20:29 -07:00
2023-06-21 18:28:54 -07:00
return glcr::OK;
2023-06-15 16:20:29 -07:00
}
void DenaliServer::HandleResponse(ResponseContext& response, uint64_t lba,
2023-06-21 23:14:42 -07:00
uint64_t size, z_cap_t mem) {
DenaliReadResponse resp{
.device_id = 0,
.lba = lba,
.size = size,
};
check(response.WriteStructWithCap<DenaliReadResponse>(resp, mem));
}