2023-06-12 19:20:51 -07:00
|
|
|
#pragma once
|
|
|
|
|
2023-06-21 18:38:11 -07:00
|
|
|
#include <glacier/status/error.h>
|
2023-11-22 14:39:27 -08:00
|
|
|
#include <mammoth/util/memory_region.h>
|
2023-06-17 01:45:53 -07:00
|
|
|
#include <ztypes.h>
|
2023-06-12 19:20:51 -07:00
|
|
|
|
|
|
|
#include "ahci/ahci.h"
|
2023-06-16 01:31:23 -07:00
|
|
|
#include "ahci/command.h"
|
2023-06-12 19:20:51 -07:00
|
|
|
|
|
|
|
class AhciDevice {
|
|
|
|
public:
|
|
|
|
AhciDevice() {}
|
|
|
|
// Caller retains ownership of the pointer.
|
|
|
|
AhciDevice(AhciPort* port_struct);
|
|
|
|
|
|
|
|
void DumpInfo();
|
|
|
|
|
2023-06-12 23:32:24 -07:00
|
|
|
bool IsInit() { return port_struct_ != nullptr && command_structures_; }
|
2023-06-12 19:20:51 -07:00
|
|
|
|
2023-06-21 18:38:11 -07:00
|
|
|
glcr::ErrorCode IssueCommand(Command* command);
|
2023-06-12 19:20:51 -07:00
|
|
|
|
|
|
|
void HandleIrq();
|
|
|
|
|
2023-06-16 01:31:23 -07:00
|
|
|
AhciDevice(const AhciDevice&) = delete;
|
|
|
|
AhciDevice& operator=(const AhciDevice&) = delete;
|
|
|
|
|
2023-06-12 19:20:51 -07:00
|
|
|
private:
|
|
|
|
AhciPort* port_struct_ = nullptr;
|
2023-11-22 14:59:41 -08:00
|
|
|
mmth::OwnedMemoryRegion command_structures_;
|
2023-06-12 19:20:51 -07:00
|
|
|
|
|
|
|
CommandList* command_list_ = nullptr;
|
|
|
|
ReceivedFis* received_fis_ = nullptr;
|
2023-07-05 14:32:19 -07:00
|
|
|
CommandTable* command_tables_ = nullptr;
|
2023-06-12 23:32:24 -07:00
|
|
|
|
2023-06-16 01:31:23 -07:00
|
|
|
Command* commands_[32];
|
|
|
|
volatile uint32_t commands_issued_ = 0;
|
2023-06-12 19:20:51 -07:00
|
|
|
};
|