2016-01-15 23 views
11

USB flash üzerinde FatFs ile bir dosya oluşturmaya çalışıyorum, ancak ilk kez dosya sistemi montajı için önyükleme sektörünü okumaya çalıştığım f_open numaram bu fonksiyonda kilitleniyor.STM32 USB OTG HOST Kütüphanesi, FatFs ile dosya oluşturmaya çalışıyor

DRESULT disk_read (
        BYTE drv,   /* Physical drive number (0) */ 
        BYTE *buff,   /* Pointer to the data buffer to store read data */ 
        DWORD sector,  /* Start sector number (LBA) */ 
        BYTE count   /* Sector count (1..255) */ 
        ) 
{ 
    BYTE status = USBH_MSC_OK; 

    if (drv || !count) return RES_PARERR; 
    if (Stat & STA_NOINIT) return RES_NOTRDY; 


    if(HCD_IsDeviceConnected(&USB_OTG_Core)) 
    { 

    do 
    { 
     status = USBH_MSC_Read10(&USB_OTG_Core, buff,sector,512 * count); 
     USBH_MSC_HandleBOTXfer(&USB_OTG_Core ,&USB_Host); 

     if(!HCD_IsDeviceConnected(&USB_OTG_Core)) 
     { 
     return RES_ERROR; 
     }  
    } 
    while(status == USBH_MSC_BUSY); // Loop wich create hanging state 
    } 

    if(status == USBH_MSC_OK) 
    return RES_OK; 
    return RES_ERROR; 

} 

temel sorun döngü wich Yani bu önlemek için ne bilmiyorum devleti

while(status == USBH_MSC_BUSY); 

asılı oluşturur olduğunu. debuger kullanarak ben tip USBH_BOTXfer_TypeDefUSBH_MSC_Read10 fonksiyonun switch ifadesinin yukarı eşit CMD_UNINITIALIZED_STATE wich aslında neden bayan, yani devlet yapısının USBH_MSC_BOTXferParam parametresi CmdStateMachine kaynaklanır keşfederler.

/** 
    * @brief USBH_MSC_Read10 
    *   Issue the read command to the device. Once the response received, 
    *   it updates the status to upper layer 
    * @param dataBuffer : DataBuffer will contain the data to be read 
    * @param address : Address from which the data will be read 
    * @param nbOfbytes : NbOfbytes to be read 
    * @retval Status 
    */ 
uint8_t USBH_MSC_Read10(USB_OTG_CORE_HANDLE *pdev, 
         uint8_t *dataBuffer, 
         uint32_t address, 
         uint32_t nbOfbytes) 
{ 
    uint8_t index; 
    static USBH_MSC_Status_TypeDef status = USBH_MSC_BUSY; 
    uint16_t nbOfPages; 
    status = USBH_MSC_BUSY; 

    if(HCD_IsDeviceConnected(pdev)) 
    { 
    switch(USBH_MSC_BOTXferParam.CmdStateMachine) 
    { 
    case CMD_SEND_STATE: 
     /*Prepare the CBW and relevent field*/ 
     USBH_MSC_CBWData.field.CBWTransferLength = nbOfbytes; 
     USBH_MSC_CBWData.field.CBWFlags = USB_EP_DIR_IN; 
     USBH_MSC_CBWData.field.CBWLength = CBW_LENGTH; 

     USBH_MSC_BOTXferParam.pRxTxBuff = dataBuffer; 

     for(index = CBW_CB_LENGTH; index != 0; index--) 
     { 
     USBH_MSC_CBWData.field.CBWCB[index] = 0x00; 
     } 

     USBH_MSC_CBWData.field.CBWCB[0] = OPCODE_READ10; 

     /*logical block address*/ 

     USBH_MSC_CBWData.field.CBWCB[2] = (((uint8_t*)&address)[3]); 
     USBH_MSC_CBWData.field.CBWCB[3] = (((uint8_t*)&address)[2]); 
     USBH_MSC_CBWData.field.CBWCB[4] = (((uint8_t*)&address)[1]); 
     USBH_MSC_CBWData.field.CBWCB[5] = (((uint8_t*)&address)[0]); 

     /*USBH_MSC_PAGE_LENGTH = 512*/ 
     nbOfPages = nbOfbytes/ USBH_MSC_PAGE_LENGTH; 

     /*Tranfer length */ 
     USBH_MSC_CBWData.field.CBWCB[7] = (((uint8_t *)&nbOfPages)[1]) ; 
     USBH_MSC_CBWData.field.CBWCB[8] = (((uint8_t *)&nbOfPages)[0]) ; 


     USBH_MSC_BOTXferParam.BOTState = USBH_MSC_SEND_CBW; 
     /* Start the transfer, then let the state machine 
     magage the other transactions */ 
     USBH_MSC_BOTXferParam.MSCState = USBH_MSC_BOT_USB_TRANSFERS; 
     USBH_MSC_BOTXferParam.BOTXferStatus = USBH_MSC_BUSY; 
     USBH_MSC_BOTXferParam.CmdStateMachine = CMD_WAIT_STATUS; 

     status = USBH_MSC_BUSY; 

     break; 

    case CMD_WAIT_STATUS: 

     if((USBH_MSC_BOTXferParam.BOTXferStatus == USBH_MSC_OK) && \ 
     (HCD_IsDeviceConnected(pdev))) 
     { 
     /* Commands successfully sent and Response Received */  
     USBH_MSC_BOTXferParam.CmdStateMachine = CMD_SEND_STATE; 
     status = USBH_MSC_OK;  
     } 
     else if ((USBH_MSC_BOTXferParam.BOTXferStatus == USBH_MSC_FAIL) && \ 
     (HCD_IsDeviceConnected(pdev))) 
     { 
     /* Failure Mode */ 
     USBH_MSC_BOTXferParam.CmdStateMachine = CMD_SEND_STATE; 
     } 

     else if (USBH_MSC_BOTXferParam.BOTXferStatus == USBH_MSC_PHASE_ERROR) 
     { 
     /* Failure Mode */ 
     USBH_MSC_BOTXferParam.CmdStateMachine = CMD_SEND_STATE; 
     status = USBH_MSC_PHASE_ERROR;  
     } 
     else 
     { 
     /* Wait for the Commands to get Completed */ 
     /* NO Change in state Machine */ 
     } 
     break; 

    default: 
     break; 
    } 
    } 
    return status; 
} 

İşte USBH_BOTXfer_TypeDef tip bildirimi; Hata ayıklamak sırasında

typedef struct _BOTXfer 
{ 
uint8_t MSCState; 
uint8_t MSCStateBkp; 
uint8_t MSCStateCurrent; 
uint8_t CmdStateMachine; 
uint8_t BOTState; 
uint8_t BOTStateBkp; 
uint8_t* pRxTxBuff; 
uint16_t DataLength; 
uint8_t BOTXferErrorCount; 
uint8_t BOTXferStatus; 
} USBH_BOTXfer_TypeDef; 

bundan tüm alanları 0x00 olduğunu keşfeder.

İşte benim FATFS

int main(void) 
{ 
    FATFS Fat; 
    FIL file; 
    FRESULT fr; 

    RCC->AHB1ENR |= RCC_AHB1ENR_GPIODEN; 

    /* Enable SWO output */ 
    DBGMCU->CR = 0x00000020; 

    GPIOD->MODER=0x55000000; 
    GPIOD->OTYPER = 0x00000000; 
    GPIOD->OSPEEDR = 0x00000001; 

    while(1) 
    { 
     if (!USB_MSC_IsInitialized()) 
     { 
      USB_MSC_Initialize(); 
     } 

     if (USB_MSC_IsConnected()) 
     { 
      GPIOD->ODR = (1 << 15); 

      disk_initialize(0); 

      fr = f_mount(0, &Fat); 

      if(fr == FR_OK) 
      {   
       fr = f_open(&file,"0:DP_lab8.pdf",(FA_CREATE_ALWAYS | FA_WRITE)); 

       if (fr == FR_OK) 
       { 
        f_close(&file); 
       } 

       f_mount(0, NULL); 
      } 
     } 
     else 
     { 
      GPIOD->ODR = (1 << 14); 
     } 

     USB_MSC_Main(); 
    } 
} 

USB_MSC_IsConnected işlevi aramaları şunlardır:

int USB_MSC_IsConnected(void) 
{ 
    if (g_USB_MSC_HostStatus == USB_DEV_NOT_SUPPORTED) 
    { 
     USB_MSC_Uninitialize(); 
    } 

    return !(g_USB_MSC_HostStatus == USB_DEV_DETACHED || 
     g_USB_MSC_HostStatus == USB_HOST_NO_INIT || 
     g_USB_MSC_HostStatus == USB_DEV_NOT_SUPPORTED); 
} 

Ve cihaz devletler şunlardır:

typedef enum 
{ 
    USB_HOST_NO_INIT = 0, /* USB interface not initialized */ 
    USB_DEV_DETACHED,  /* no device connected */ 
    USB_SPEED_ERROR,  /* unsupported USB speed */ 
    USB_DEV_NOT_SUPPORTED, /* unsupported device */ 
    USB_DEV_WRITE_PROTECT, /* device is write protected */ 
    USB_OVER_CURRENT,  /* overcurrent detected */ 
    USB_DEV_CONNECTED  /* device connected and ready */ 
} USB_HostStatus; 

g_USB_MSC_HostStatus değeri standart USB HOST kullanıcı tarafından alınır geri aramaları.

+1

bir [MCVE] sağlar. Ama bu olabilir, dr. ST kütüphaneleri notouriously bloatware. Bu gerçekten ** ise, orada asılı kalıyor, bayrakların ayarlandığı yeri ve neden temizlenmediğini kontrol et. Muhtemelen bir kesme işleyicisi. Kesme noktalarını ve bir hata ayıklayıcısını kullanın. – Olaf

+0

Disk_read() öğesini nerede arayacağınızı göremiyorum. Yürütülen kod örneğini sağlayabilir misiniz? –

+1

@Ivan Angelov: HAL seviyesinde işlevli şişeler disio.h dosyasında arayüz sağladı, dosya bizim cihazımızdaki STM32F4 USB OTG HOST sürücüsündeki cihaz sürücüsü kullanımıyla manuel olarak uygulandı (usbh_msc_fatfs.c). FatFs, bu işlevi FLASH SÜRÜCÜ durumumdaki fiziksel aygıttan okunması için çağırır. – Mykola

cevap

1

Ben ST konak kütüphanesinde bir hata olduğunu düşünüyorum. USB ana bilgisayarım numaralandırma aşamasından geçemediğinden onu avladım. Bir düzeltme yaptıktan sonra yığın Tamam.

union _USB_Setup yılında usbh_def.h dosya (herhangi bir çip, sadece F7, herhangi bir sürümü, sadece V1.13.0 "STM32Cube/Depo/STM32Cube_FW_F7_V1.13.0/ara katman/ST/STM32_USB_Host_Library/Çekirdek/Inc" de var olduğu). Uint16_t bmRequestType ve uint16_t bRequest var. Bu iki dosya, USB özelliklerinden dolayı uint8_t olmalıdır. Bu sorunu düzeltmek, USB ana makinesini gerektiği şekilde yaptı. Numaralandırma aşaması tamam, diğer tüm aşamaları da geçer.

+0

Tüm bu alanlar varsayılan olarak "uint8_t" türüne sahiptir, ancak çalışmaz. – Mykola

+0

Tamam, flash sürücünüz usb host tarafından numaralandırılıyor mu? Ve sonra, aygıt sınıfı başlıyor mu? – elephant

+0

İlginiz için teşekkür ederim, ancak şu anda mikrodenetleyiciye erişemiyorum, bu yüzden size biraz ödül vereceğim. – Mykola