msc host, use usbh_get_enum_buf() for set_config() process
This commit is contained in:
@@ -79,11 +79,6 @@ typedef struct {
|
|||||||
static msch_interface_t _msch_itf[CFG_TUH_DEVICE_MAX];
|
static msch_interface_t _msch_itf[CFG_TUH_DEVICE_MAX];
|
||||||
CFG_TUH_MEM_SECTION static msch_epbuf_t _msch_epbuf[CFG_TUH_DEVICE_MAX];
|
CFG_TUH_MEM_SECTION static msch_epbuf_t _msch_epbuf[CFG_TUH_DEVICE_MAX];
|
||||||
|
|
||||||
// Epbuf for enumeration, shared for all devices
|
|
||||||
CFG_TUH_MEM_SECTION static struct {
|
|
||||||
TUH_EPBUF_DEF(buf, 32);
|
|
||||||
} _msch_enum_buf;
|
|
||||||
|
|
||||||
TU_ATTR_ALWAYS_INLINE static inline msch_interface_t* get_itf(uint8_t daddr) {
|
TU_ATTR_ALWAYS_INLINE static inline msch_interface_t* get_itf(uint8_t daddr) {
|
||||||
return &_msch_itf[daddr - 1];
|
return &_msch_itf[daddr - 1];
|
||||||
}
|
}
|
||||||
@@ -309,7 +304,9 @@ void msch_close(uint8_t dev_addr) {
|
|||||||
|
|
||||||
// invoke Application Callback
|
// invoke Application Callback
|
||||||
if (p_msc->mounted) {
|
if (p_msc->mounted) {
|
||||||
if (tuh_msc_umount_cb) tuh_msc_umount_cb(dev_addr);
|
if (tuh_msc_umount_cb) {
|
||||||
|
tuh_msc_umount_cb(dev_addr);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tu_memclr(p_msc, sizeof(msch_interface_t));
|
tu_memclr(p_msc, sizeof(msch_interface_t));
|
||||||
@@ -422,11 +419,12 @@ bool msch_set_config(uint8_t daddr, uint8_t itf_num) {
|
|||||||
.wLength = 1
|
.wLength = 1
|
||||||
};
|
};
|
||||||
|
|
||||||
|
uint8_t* enum_buf = usbh_get_enum_buf();
|
||||||
tuh_xfer_t xfer = {
|
tuh_xfer_t xfer = {
|
||||||
.daddr = daddr,
|
.daddr = daddr,
|
||||||
.ep_addr = 0,
|
.ep_addr = 0,
|
||||||
.setup = &request,
|
.setup = &request,
|
||||||
.buffer = _msch_enum_buf.buf,
|
.buffer = enum_buf,
|
||||||
.complete_cb = config_get_maxlun_complete,
|
.complete_cb = config_get_maxlun_complete,
|
||||||
.user_data = 0
|
.user_data = 0
|
||||||
};
|
};
|
||||||
@@ -441,7 +439,8 @@ static void config_get_maxlun_complete(tuh_xfer_t* xfer) {
|
|||||||
|
|
||||||
// MAXLUN's response is minus 1 by specs, STALL means 1
|
// MAXLUN's response is minus 1 by specs, STALL means 1
|
||||||
if (XFER_RESULT_SUCCESS == xfer->result) {
|
if (XFER_RESULT_SUCCESS == xfer->result) {
|
||||||
p_msc->max_lun = _msch_enum_buf.buf[0] + 1;
|
uint8_t* enum_buf = usbh_get_enum_buf();
|
||||||
|
p_msc->max_lun = enum_buf[0] + 1;
|
||||||
} else {
|
} else {
|
||||||
p_msc->max_lun = 1;
|
p_msc->max_lun = 1;
|
||||||
}
|
}
|
||||||
@@ -457,18 +456,19 @@ static void config_get_maxlun_complete(tuh_xfer_t* xfer) {
|
|||||||
static bool config_test_unit_ready_complete(uint8_t dev_addr, tuh_msc_complete_data_t const* cb_data) {
|
static bool config_test_unit_ready_complete(uint8_t dev_addr, tuh_msc_complete_data_t const* cb_data) {
|
||||||
msc_cbw_t const* cbw = cb_data->cbw;
|
msc_cbw_t const* cbw = cb_data->cbw;
|
||||||
msc_csw_t const* csw = cb_data->csw;
|
msc_csw_t const* csw = cb_data->csw;
|
||||||
|
uint8_t* enum_buf = usbh_get_enum_buf();
|
||||||
|
|
||||||
if (csw->status == 0) {
|
if (csw->status == 0) {
|
||||||
// Unit is ready, read its capacity
|
// Unit is ready, read its capacity
|
||||||
TU_LOG_DRV("SCSI Read Capacity\r\n");
|
TU_LOG_DRV("SCSI Read Capacity\r\n");
|
||||||
tuh_msc_read_capacity(dev_addr, cbw->lun, (scsi_read_capacity10_resp_t*) (uintptr_t) _msch_enum_buf.buf,
|
tuh_msc_read_capacity(dev_addr, cbw->lun, (scsi_read_capacity10_resp_t*) (uintptr_t) enum_buf,
|
||||||
config_read_capacity_complete, 0);
|
config_read_capacity_complete, 0);
|
||||||
} else {
|
} else {
|
||||||
// Note: During enumeration, some device fails Test Unit Ready and require a few retries
|
// Note: During enumeration, some device fails Test Unit Ready and require a few retries
|
||||||
// with Request Sense to start working !!
|
// with Request Sense to start working !!
|
||||||
// TODO limit number of retries
|
// TODO limit number of retries
|
||||||
TU_LOG_DRV("SCSI Request Sense\r\n");
|
TU_LOG_DRV("SCSI Request Sense\r\n");
|
||||||
TU_ASSERT(tuh_msc_request_sense(dev_addr, cbw->lun, _msch_enum_buf.buf, config_request_sense_complete, 0));
|
TU_ASSERT(tuh_msc_request_sense(dev_addr, cbw->lun, enum_buf, config_request_sense_complete, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@@ -488,15 +488,18 @@ static bool config_read_capacity_complete(uint8_t dev_addr, tuh_msc_complete_dat
|
|||||||
msc_csw_t const* csw = cb_data->csw;
|
msc_csw_t const* csw = cb_data->csw;
|
||||||
TU_ASSERT(csw->status == 0);
|
TU_ASSERT(csw->status == 0);
|
||||||
msch_interface_t* p_msc = get_itf(dev_addr);
|
msch_interface_t* p_msc = get_itf(dev_addr);
|
||||||
|
uint8_t* enum_buf = usbh_get_enum_buf();
|
||||||
|
|
||||||
// Capacity response field: Block size and Last LBA are both Big-Endian
|
// Capacity response field: Block size and Last LBA are both Big-Endian
|
||||||
scsi_read_capacity10_resp_t* resp = (scsi_read_capacity10_resp_t*) (uintptr_t) _msch_enum_buf.buf;
|
scsi_read_capacity10_resp_t* resp = (scsi_read_capacity10_resp_t*) (uintptr_t) enum_buf;
|
||||||
p_msc->capacity[cbw->lun].block_count = tu_ntohl(resp->last_lba) + 1;
|
p_msc->capacity[cbw->lun].block_count = tu_ntohl(resp->last_lba) + 1;
|
||||||
p_msc->capacity[cbw->lun].block_size = tu_ntohl(resp->block_size);
|
p_msc->capacity[cbw->lun].block_size = tu_ntohl(resp->block_size);
|
||||||
|
|
||||||
// Mark enumeration is complete
|
// Mark enumeration is complete
|
||||||
p_msc->mounted = true;
|
p_msc->mounted = true;
|
||||||
if (tuh_msc_mount_cb) tuh_msc_mount_cb(dev_addr);
|
if (tuh_msc_mount_cb) {
|
||||||
|
tuh_msc_mount_cb(dev_addr);
|
||||||
|
}
|
||||||
|
|
||||||
// notify usbh that driver enumeration is complete
|
// notify usbh that driver enumeration is complete
|
||||||
usbh_driver_set_config_complete(dev_addr, p_msc->itf_num);
|
usbh_driver_set_config_complete(dev_addr, p_msc->itf_num);
|
||||||
|
|||||||
Reference in New Issue
Block a user