complete msc device with os
This commit is contained in:
@@ -23,7 +23,7 @@
|
||||
#include "usbd_core.h"
|
||||
#include "usbd_msc.h"
|
||||
#include "usb_scsi.h"
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
#include "usb_osal.h"
|
||||
#endif
|
||||
|
||||
@@ -34,9 +34,9 @@
|
||||
#define MASS_STORAGE_BULK_EP_MPS 512
|
||||
#endif
|
||||
|
||||
#define THREAD_OP_READ_QUEUED 1
|
||||
#define THREAD_OP_WRITE_QUEUED 2
|
||||
#define THREAD_OP_WRITE_DONE 3
|
||||
#define MSC_THREAD_OP_READ_MEM 1
|
||||
#define MSC_THREAD_OP_WRITE_MEM 2
|
||||
#define MSC_THREAD_OP_WRITE_DONE 3
|
||||
|
||||
#define MSD_OUT_EP_IDX 0
|
||||
#define MSD_IN_EP_IDX 1
|
||||
@@ -76,7 +76,7 @@ struct usbd_msc_cfg_priv {
|
||||
/*memory OK (after a usbd_msc_memory_verify)*/
|
||||
static bool memOK;
|
||||
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
static volatile uint8_t thread_op;
|
||||
static usb_osal_sem_t msc_sem;
|
||||
static usb_osal_thread_t msc_thread;
|
||||
@@ -216,17 +216,19 @@ static void SCSI_SetSenseData(uint32_t KCQ)
|
||||
usbd_msc_cfg.ASQ = (uint8_t)(KCQ);
|
||||
}
|
||||
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
static void usbd_msc_thread_memory_read_done(void)
|
||||
{
|
||||
size_t flags;
|
||||
uint32_t transfer_len;
|
||||
uint32_t offset;
|
||||
|
||||
USB_LOG_DBG("read addr:%d\r\n", usbd_msc_cfg.scsi_blk_addr);
|
||||
|
||||
transfer_len = MIN(usbd_msc_cfg.scsi_blk_len, MASS_STORAGE_BULK_EP_MPS);
|
||||
flags = usb_osal_enter_critical_section();
|
||||
|
||||
usbd_ep_write(mass_ep_data[MSD_IN_EP_IDX].ep_addr,
|
||||
&usbd_msc_cfg.block_buffer[usbd_msc_cfg.scsi_blk_addr % usbd_msc_cfg.scsi_blk_size], transfer_len, NULL);
|
||||
transfer_len = MIN(usbd_msc_cfg.scsi_blk_len, MASS_STORAGE_BULK_EP_MPS);
|
||||
offset = usbd_msc_cfg.scsi_blk_addr % usbd_msc_cfg.scsi_blk_size;
|
||||
|
||||
usbd_msc_cfg.scsi_blk_addr += transfer_len;
|
||||
usbd_msc_cfg.scsi_blk_len -= transfer_len;
|
||||
@@ -235,6 +237,10 @@ static void usbd_msc_thread_memory_read_done(void)
|
||||
if (usbd_msc_cfg.scsi_blk_len == 0) {
|
||||
usbd_msc_cfg.stage = MSC_SEND_CSW;
|
||||
}
|
||||
usb_osal_leave_critical_section(flags);
|
||||
|
||||
usbd_ep_write(mass_ep_data[MSD_IN_EP_IDX].ep_addr,
|
||||
&usbd_msc_cfg.block_buffer[offset], transfer_len, NULL);
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -248,8 +254,8 @@ static bool SCSI_processRead(void)
|
||||
|
||||
/* we read an entire block */
|
||||
if (!(usbd_msc_cfg.scsi_blk_addr % usbd_msc_cfg.scsi_blk_size)) {
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
thread_op = THREAD_OP_READ_QUEUED;
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
thread_op = MSC_THREAD_OP_READ_MEM;
|
||||
usb_osal_sem_give(msc_sem);
|
||||
return true;
|
||||
#else
|
||||
@@ -274,25 +280,30 @@ static bool SCSI_processRead(void)
|
||||
return true;
|
||||
}
|
||||
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
static void usbd_msc_thread_memory_write_done()
|
||||
{
|
||||
size_t flags;
|
||||
uint32_t bytes_read;
|
||||
USB_LOG_DBG("write addr:%d\r\n", usbd_msc_cfg.scsi_blk_addr);
|
||||
|
||||
flags = usb_osal_enter_critical_section();
|
||||
|
||||
bytes_read = current_byte_read;
|
||||
|
||||
usbd_msc_cfg.scsi_blk_addr += bytes_read;
|
||||
usbd_msc_cfg.scsi_blk_len -= bytes_read;
|
||||
usbd_msc_cfg.csw.dDataResidue -= bytes_read;
|
||||
|
||||
usb_osal_leave_critical_section(flags);
|
||||
|
||||
thread_op = MSC_THREAD_OP_WRITE_DONE;
|
||||
/*set ep ack to recv next data*/
|
||||
usbd_ep_read(mass_ep_data[MSD_OUT_EP_IDX].ep_addr, NULL, 0, NULL);
|
||||
|
||||
if (usbd_msc_cfg.scsi_blk_len == 0) {
|
||||
sendCSW(CSW_STATUS_CMD_PASSED);
|
||||
}
|
||||
|
||||
thread_op = THREAD_OP_WRITE_DONE;
|
||||
/*set ep ack to recv next data*/
|
||||
usbd_ep_read(mass_ep_data[MSD_OUT_EP_IDX].ep_addr, NULL, 0, NULL);
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -307,8 +318,8 @@ static bool SCSI_processWrite()
|
||||
|
||||
/* if the array is filled, write it in memory */
|
||||
if ((usbd_msc_cfg.scsi_blk_addr % usbd_msc_cfg.scsi_blk_size) + bytes_read >= usbd_msc_cfg.scsi_blk_size) {
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
thread_op = THREAD_OP_WRITE_QUEUED;
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
thread_op = MSC_THREAD_OP_WRITE_MEM;
|
||||
current_byte_read = bytes_read;
|
||||
usb_osal_sem_give(msc_sem);
|
||||
return true;
|
||||
@@ -975,8 +986,8 @@ static void mass_storage_bulk_out(uint8_t ep)
|
||||
break;
|
||||
}
|
||||
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
if (thread_op != THREAD_OP_WRITE_QUEUED) {
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
if (thread_op != MSC_THREAD_OP_WRITE_MEM) {
|
||||
/*set ep ack to recv next data*/
|
||||
usbd_ep_read(ep, NULL, 0, NULL);
|
||||
}
|
||||
@@ -1040,20 +1051,20 @@ void msc_storage_notify_handler(uint8_t event, void *arg)
|
||||
}
|
||||
}
|
||||
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
static void usbd_msc_thread(void *argument)
|
||||
{
|
||||
while (1) {
|
||||
usb_osal_sem_take(msc_sem, 0xffffffff);
|
||||
|
||||
switch (thread_op) {
|
||||
case THREAD_OP_READ_QUEUED:
|
||||
case MSC_THREAD_OP_READ_MEM:
|
||||
if (usbd_msc_sector_read((usbd_msc_cfg.scsi_blk_addr / usbd_msc_cfg.scsi_blk_size), usbd_msc_cfg.block_buffer, usbd_msc_cfg.scsi_blk_size) != 0) {
|
||||
SCSI_SetSenseData(SCSI_KCQHE_UREINRESERVEDAREA);
|
||||
}
|
||||
usbd_msc_thread_memory_read_done();
|
||||
break;
|
||||
case THREAD_OP_WRITE_QUEUED:
|
||||
case MSC_THREAD_OP_WRITE_MEM:
|
||||
if (usbd_msc_sector_write((usbd_msc_cfg.scsi_blk_addr / usbd_msc_cfg.scsi_blk_size), usbd_msc_cfg.block_buffer, usbd_msc_cfg.scsi_blk_size) != 0) {
|
||||
SCSI_SetSenseData(SCSI_KCQHE_WRITEFAULT);
|
||||
}
|
||||
@@ -1096,7 +1107,7 @@ void usbd_msc_class_init(uint8_t out_ep, uint8_t in_ep)
|
||||
usbd_msc_cfg.block_buffer = usb_iomalloc(usbd_msc_cfg.scsi_blk_size * sizeof(uint8_t));
|
||||
}
|
||||
|
||||
#if CONFIG_USBDEV_MSC_THREAD_ENABLE
|
||||
#ifdef CONFIG_USBDEV_MSC_THREAD
|
||||
msc_sem = usb_osal_sem_create(1);
|
||||
msc_thread = usb_osal_thread_create("usbd_msc", CONFIG_USBDEV_MSC_STACKSIZE, CONFIG_USBDEV_MSC_PRIO, usbd_msc_thread, NULL);
|
||||
if (msc_thread == NULL) {
|
||||
|
||||
Reference in New Issue
Block a user