X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/c4d08ac5260bb26db10bcfd9dc6fd2db60efebe9..a362b4b2c4abbf2da6ec14cb44a8685a81107f6a:/lunaix-os/hal/ahci/utils.c diff --git a/lunaix-os/hal/ahci/utils.c b/lunaix-os/hal/ahci/utils.c index 96d163b..4a86cc3 100644 --- a/lunaix-os/hal/ahci/utils.c +++ b/lunaix-os/hal/ahci/utils.c @@ -17,18 +17,18 @@ #define IDDEV_OFFLPP 106 #define IDDEV_OFFCAPABILITIES 49 -static uint32_t cdb_size[] = { SCSI_CDB12, SCSI_CDB16, 0, 0 }; +static u32_t cdb_size[] = { SCSI_CDB12, SCSI_CDB16, 0, 0 }; void ahci_parse_dev_info(struct hba_device* dev_info, uint16_t* data) { - dev_info->max_lba = *((uint32_t*)(data + IDDEV_OFFMAXLBA)); - dev_info->block_size = *((uint32_t*)(data + IDDEV_OFFLSECSIZE)); + dev_info->max_lba = *((u32_t*)(data + IDDEV_OFFMAXLBA)); + dev_info->block_size = *((u32_t*)(data + IDDEV_OFFLSECSIZE)); dev_info->cbd_size = cdb_size[(*data & 0x3)]; dev_info->wwn = *(uint64_t*)(data + IDDEV_OFFWWN); dev_info->block_per_sec = 1 << (*(data + IDDEV_OFFLPP) & 0xf); dev_info->alignment_offset = *(data + IDDEV_OFFALIGN) & 0x3fff; - dev_info->capabilities = *((uint32_t*)(data + IDDEV_OFFCAPABILITIES)); + dev_info->capabilities = *((u32_t*)(data + IDDEV_OFFCAPABILITIES)); if (!dev_info->block_size) { dev_info->block_size = 512; @@ -85,4 +85,19 @@ ahci_try_send(struct hba_port* port, int slot) hba_clear_reg(port->regs[HBA_RPxIS]); return retries < MAX_RETRY; +} + +void +ahci_post(struct hba_port* port, struct hba_cmd_state* state, int slot) +{ + int bitmask = 1 << slot; + + // 确保端口是空闲的 + wait_until(!(port->regs[HBA_RPxTFD] & (HBA_PxTFD_BSY | HBA_PxTFD_DRQ))); + + hba_clear_reg(port->regs[HBA_RPxIS]); + + port->cmdctx.issued[slot] = state; + port->cmdctx.tracked_ci |= bitmask; + port->regs[HBA_RPxCI] |= bitmask; } \ No newline at end of file