X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/eb037efe9f30ae166684e99146024abf8740984d..df1e857ac4d1410ae2bd354e361210b842ab7bc8:/lunaix-os/includes/hal/ahci/ahci.h?ds=sidebyside diff --git a/lunaix-os/includes/hal/ahci/ahci.h b/lunaix-os/includes/hal/ahci/ahci.h index acd779b..2ed135a 100644 --- a/lunaix-os/includes/hal/ahci/ahci.h +++ b/lunaix-os/includes/hal/ahci/ahci.h @@ -1,6 +1,8 @@ #ifndef __LUNAIX_AHCI_H #define __LUNAIX_AHCI_H +#include "hba.h" + /* * Macro naming rule: * HBA_R[xxx] @@ -12,6 +14,13 @@ #define AHCI_HBA_CLASS 0x10601 +struct ahci_driver +{ + struct llist_header ahci_drvs; + struct ahci_hba hba; + int id; +}; + /** * @brief 初始化AHCI与HBA * @@ -20,12 +29,29 @@ void ahci_init(); void -ahci_list_device(); +ahci_parse_dev_info(struct hba_device* dev_info, uint16_t* data); -unsigned int -ahci_get_port_usage(); +void +ahci_parsestr(char* str, uint16_t* reg_start, int size_word); -struct hba_port* -ahci_get_port(unsigned int index); +/** + * @brief Issue a HBA command (synchronized) + * + * @param port + * @param slot + * @return int + */ +int +ahci_try_send(struct hba_port* port, int slot); + +/** + * @brief Issue a HBA command (asynchronized) + * + * @param port + * @param state + * @param slot + */ +void +ahci_post(struct hba_port* port, struct hba_cmd_state* state, int slot); #endif /* __LUNAIX_AHCI_H */