cancel
Showing results for 
Search instead for 
Did you mean: 

Knowledge Base Articles

マルチチャネルコミットバッファでの無効なシーケンスエラー - KBA218830 - Community Translated (JA)

Employee

マルチチャネルコミットバッファでの無効なシーケンスエラー - KBA218830 - Community Translated (JA)

Community Translated by RyKi_1693141          Version: **

Translation - English: Invalid Sequence Error in Multi-Channel Commit Buffer - KBA218830

質問:

"Error in CyU3PDmaMultiChannelCommitBuffer: code 71 "というメッセージがFX3で動画をストリーミングしているときにUART端末に表示されます。

このエラーの原因と復旧方法を教えてください。

回答:

"Error in CyU3PDmaMultiChannelCommitBuffer: code 71 "というメッセージは、DMAバッファオーバーフローが発生した場合に表示されます。

code 71のエラーは「CY_U3P_ERROR_INVALID_SEQUENCE」エラーを指します。

このエラーは、UVC ホストアプリケーションが DMA バッファをクリアするのに十分な速さで IN トークンを発行しなかった場合に発生する可能性があります。

code 71のエラーから回復するには、

1.ファームウェアに割り当てられた DMA バッファ領域を増やす。

2.AN75779 に関連付けられたサンプル・プロジェクトに以下を実装します。

 -1.CyU3PDmaMultiChannelCommitBuffer() APIがCY_U3P_SUCCESSを返すのに失敗した場合、CyFxUvcApplnDmaCallback()関数にフラグ(例えば、commit_buffer_failure)を設定する。

 -2,UVCAppThread_Entry()関数のfor(;;)ループで、このフラグがセットされているかどうかを確認します。セットされている場合は、以下のコードスニペットを実装して、DMA チャネルをリセットし、GPIF II ステートマシンを再起動します。

if (commit_buffer_failure == 1)

  

            {

  

                        commit_buffer_failure = 0;

  

                        /* Stop the GPIF state machine to stop data transfers through FX3 */

  

                        CyU3PGpifDisable (CyFalse);

  

                        streamingStarted = CyFalse;

  

  

                        /* Place the Endpoint in NAK mode before cleaning up the pipe. */

  

                        apiRetStatus = CyU3PUsbSetEpNak (CY_FX_EP_BULK_VIDEO, CyTrue);

  

                        if (apiRetStatus != CY_U3P_SUCCESS)

  

        {

  

                                    CyU3PDebugPrint (4, "\r EP_NAK=%d\n", apiRetStatus);

  

                        }

  

                        /* Reset the DMA channel and flush the endpoint pipe. */

  

                        apiRetStatus = CyU3PDmaMultiChannelReset (&glChHandleUVCStream);

  

                        if (apiRetStatus != CY_U3P_SUCCESS)

  

      {

  

                            CyU3PDebugPrint (4, "\r DMA_RESET=%d\n", apiRetStatus);

  

                         }

  

                        apiRetStatus = CyU3PUsbFlushEp (CY_FX_EP_BULK_VIDEO);

  

                        if(apiRetStatus != CY_U3P_SUCCESS)

  

     {

  

                            CyU3PDebugPrint (4, "\r EP_FLUSH=%d\n", apiRetStatus);

  

                          }

  

                        apiRetStatus = CyU3PDmaMultiChannelSetXfer (&glChHandleUVCStream, 0, 0);

  

                        if (apiRetStatus != CY_U3P_SUCCESS)

  

                        {

  

                                    CyU3PDebugPrint (4, "\r DMA_XFER  = %d\n", apiRetStatus);

  

                        }

  

                        apiRetStatus = CyU3PUsbSetEpNak (CY_FX_EP_BULK_VIDEO, CyFalse);

  

                        if(apiRetStatus != CY_U3P_SUCCESS)

  

    {

  

                            CyU3PDebugPrint (4, "\r EP_ACK=%d\n", apiRetStatus);

  

                          }

  

           apiRetStatus = CyU3PGpifSMStart (START_SCK0, ALPHA_START_SCK0);

  

                        if (apiRetStatus != CY_U3P_SUCCESS)

  

                      {

  

                         CyU3PDebugPrint (4, "CyU3PGpifSMStart  = %d\n", apiRetStatus);

  

                        }

  

                        apiRetStatus = CyU3PGpifSMSwitch (257, 0, 257, 0, 2);

  

                        if (apiRetStatus != CY_U3P_SUCCESS)

  

                     {

  

                         CyU3PDebugPrint (4, "CyU3PGpifSMSwitch  = %d\n", apiRetStatus);

  

                      }

  

                        streamingStarted = CyTrue;

          }

0 Likes
Version history
Revision #:
1 of 1
Last update:
‎Jul 03, 2020 03:38 AM
Updated by:
 
Contributors