X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/43c43c058ededea929645fef68d15820eed1f5e9..HEAD:/lunaix-os/includes/hal/ahci/ahci.h diff --git a/lunaix-os/includes/hal/ahci/ahci.h b/lunaix-os/includes/hal/ahci/ahci.h index 2ed135a..9cf80fc 100644 --- a/lunaix-os/includes/hal/ahci/ahci.h +++ b/lunaix-os/includes/hal/ahci/ahci.h @@ -2,6 +2,7 @@ #define __LUNAIX_AHCI_H #include "hba.h" +#include /* * Macro naming rule: @@ -21,18 +22,18 @@ struct ahci_driver int id; }; -/** - * @brief 初始化AHCI与HBA - * - */ -void -ahci_init(); +struct ahci_driver_param +{ + ptr_t mmio_base; + size_t mmio_size; + irq_t irq; +}; void -ahci_parse_dev_info(struct hba_device* dev_info, uint16_t* data); +ahci_parse_dev_info(struct hba_device* dev_info, u16_t* data); void -ahci_parsestr(char* str, uint16_t* reg_start, int size_word); +ahci_parsestr(char* str, u16_t* reg_start, int size_word); /** * @brief Issue a HBA command (synchronized) @@ -54,4 +55,10 @@ ahci_try_send(struct hba_port* port, int slot); void ahci_post(struct hba_port* port, struct hba_cmd_state* state, int slot); +struct ahci_driver* +ahci_driver_init(struct ahci_driver_param* param); + +void +ahci_hba_isr(irq_t irq, const struct hart_state* hstate); + #endif /* __LUNAIX_AHCI_H */