USB CDC Example Receive only fail

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

USB CDC Example Receive only fail

跳至解决方案
1,801 次查看
etronic_arg
Contributor III

Hi,

I just trying to do a Virtual COM communication based on the USB CDC example from SDK.
I tested the example with success.

I cancel the "echo" part of the APPTask:

static void APPTask(void)
{
    usb_status_t error = kStatus_USB_Error;
    if ((1 == s_cdcVcom.attach) && (1 == s_cdcVcom.startTransactions))
    {
        /* User Code */
        /* endpoint callback length is USB_CANCELLED_TRANSFER_LENGTH (0xFFFFFFFFU) when transfer is canceled */
        if ((0 != s_recvSize) && (USB_CANCELLED_TRANSFER_LENGTH != s_recvSize))
        {
            int32_t i;

			/* Copy Buffer to Send Buff */
            for (i = 0; i < s_recvSize; i++)
            {
                s_currSendBuf[s_sendSize++] = s_currRecvBuf[i];
            }

			s_recvSize = 0;
        }


/*
        if (s_sendSize)
        {
            uint32_t size = s_sendSize;


			s_sendSize    = 0;

            error = USB_DeviceCdcAcmSend(s_cdcVcom.cdcAcmHandle, USB_CDC_VCOM_BULK_IN_ENDPOINT, s_currSendBuf, size);

            if (error != kStatus_USB_Success)
            {
                // Failure to send Data Handling code here
            }
        }
*/

 

If I send "HELLO" wth a terminal from a PC, the first time s_currSendBuf fills with the characters.

With the second "HELLO" I send, the terminal stucks.

I just need to receive characters but not send them back.
What would be the right way to do it?

Thanks

 

标记 (3)
0 项奖励
回复
1 解答
1,712 次查看
xiangjun_rong
NXP TechSupport
NXP TechSupport

Hi,

Yes, this is a good solution. After you have data, just call the the function to send.

BR

Xiangjun Rong

USB_DeviceCdcAcmSend();

 

在原帖中查看解决方案

0 项奖励
回复
3 回复数
1,751 次查看
xiangjun_rong
NXP TechSupport
NXP TechSupport

Hi,

Can you tell us the part number you are using?

BR

XiangJun Rong

0 项奖励
回复
1,738 次查看
etronic_arg
Contributor III

Hello XiangJun,

The part I'm using is the MK27FN2M0VM115 in a custom board, but I also tested it in a FRDM-K64F.

I solve the issue partially calling the USB sending fuction without data after receiving:

 

 if (s_sendSize)
        {
            uint32_t size = s_sendSize;


			s_sendSize    = 0;

            error = USB_DeviceCdcAcmSend(s_cdcVcom.cdcAcmHandle, USB_CDC_VCOM_BULK_IN_ENDPOINT, NULL, 0);

            if (error != kStatus_USB_Success)
            {
                // Failure to send Data Handling code here
            }
        }

 

Is there a better solution?

标记 (1)
0 项奖励
回复
1,713 次查看
xiangjun_rong
NXP TechSupport
NXP TechSupport

Hi,

Yes, this is a good solution. After you have data, just call the the function to send.

BR

Xiangjun Rong

USB_DeviceCdcAcmSend();

 

0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-1965405%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3EUSB%20CDC%20%E7%A4%BA%E4%BE%8B%E4%BB%85%E6%8E%A5%E6%94%B6%E5%A4%B1%E8%B4%A5%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1965405%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3EHi%2C%3C%2FP%3E%3CP%3E%E6%88%91%E5%8F%AA%E6%98%AF%E6%83%B3%E6%A0%B9%E6%8D%AE%20SDK%20%E4%B8%AD%E7%9A%84%20USB%20CDC%20%E7%A4%BA%E4%BE%8B%E8%BF%9B%E8%A1%8C%E8%99%9A%E6%8B%9F%20COM%20%E9%80%9A%E4%BF%A1%E3%80%82%3CBR%20%2F%3E%E6%88%91%E6%88%90%E5%8A%9F%E6%B5%8B%E8%AF%95%E4%BA%86%E8%BF%99%E4%B8%AA%E4%BE%8B%E5%AD%90%E3%80%82%3C%2FP%3E%3CP%3E%E6%88%91%E5%8F%96%E6%B6%88%E4%BA%86APPTask%E7%9A%84%E2%80%9C%E5%9B%9E%E6%98%BE%E2%80%9D%E9%83%A8%E5%88%86%EF%BC%9A%3C%2FP%3E%3CPRE%20class%3D%22lia-code-sample%20language-c%22%3E%3CCODE%20translate%3D%22no%22%3Estatic%20void%20APPTask(void)%0A%7B%0A%20%20%20%20usb_status_t%20error%20%3D%20kStatus_USB_Error%3B%0A%20%20%20%20if%20((1%20%3D%3D%20s_cdcVcom.attach)%20%26amp%3B%26amp%3B%20(1%20%3D%3D%20s_cdcVcom.startTransactions))%0A%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%2F*%20User%20Code%20*%2F%0A%20%20%20%20%20%20%20%20%2F*%20endpoint%20callback%20length%20is%20USB_CANCELLED_TRANSFER_LENGTH%20(0xFFFFFFFFU)%20when%20transfer%20is%20canceled%20*%2F%0A%20%20%20%20%20%20%20%20if%20((0%20!%3D%20s_recvSize)%20%26amp%3B%26amp%3B%20(USB_CANCELLED_TRANSFER_LENGTH%20!%3D%20s_recvSize))%0A%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20int32_t%20i%3B%0A%0A%09%09%09%2F*%20Copy%20Buffer%20to%20Send%20Buff%20*%2F%0A%20%20%20%20%20%20%20%20%20%20%20%20for%20(i%20%3D%200%3B%20i%20%26lt%3B%20s_recvSize%3B%20i%2B%2B)%0A%20%20%20%20%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20s_currSendBuf%5Bs_sendSize%2B%2B%5D%20%3D%20s_currRecvBuf%5Bi%5D%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%7D%0A%0A%09%09%09s_recvSize%20%3D%200%3B%0A%20%20%20%20%20%20%20%20%7D%0A%0A%0A%2F*%0A%20%20%20%20%20%20%20%20if%20(s_sendSize)%0A%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20uint32_t%20size%20%3D%20s_sendSize%3B%0A%0A%0A%09%09%09s_sendSize%20%20%20%20%3D%200%3B%0A%0A%20%20%20%20%20%20%20%20%20%20%20%20error%20%3D%20USB_DeviceCdcAcmSend(s_cdcVcom.cdcAcmHandle%2C%20USB_CDC_VCOM_BULK_IN_ENDPOINT%2C%20s_currSendBuf%2C%20size)%3B%0A%0A%20%20%20%20%20%20%20%20%20%20%20%20if%20(error%20!%3D%20kStatus_USB_Success)%0A%20%20%20%20%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%2F%2F%20Failure%20to%20send%20Data%20Handling%20code%20here%0A%20%20%20%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%20%7D%0A*%2F%3C%2FCODE%3E%3C%2FPRE%3E%3CBR%20%2F%3E%3CP%3E%E5%A6%82%E6%9E%9C%E6%88%91%E4%BB%8E%20PC%20%E9%80%9A%E8%BF%87%E7%BB%88%E7%AB%AF%E5%8F%91%E9%80%81%E2%80%9CHELLO%E2%80%9D%EF%BC%8C%E5%88%99%20s_currSendBuf%20%E7%AC%AC%E4%B8%80%E6%AC%A1%E4%BC%9A%E5%A1%AB%E5%85%85%E5%AD%97%E7%AC%A6%E3%80%82%3C%2FP%3E%3CP%3E%E5%BD%93%E6%88%91%E5%8F%91%E9%80%81%E7%AC%AC%E4%BA%8C%E4%B8%AA%E2%80%9CHELLO%E2%80%9D%E6%97%B6%EF%BC%8C%E7%BB%88%E7%AB%AF%E5%8D%A1%E4%BD%8F%E4%BA%86%E3%80%82%3CBR%20%2F%3E%3CBR%20%2F%3E%E6%88%91%E5%8F%AA%E9%9C%80%E8%A6%81%E6%8E%A5%E6%94%B6%E5%AD%97%E7%AC%A6%E4%BD%86%E4%B8%8D%E9%9C%80%E8%A6%81%E5%B0%86%E5%85%B6%E5%8F%91%E5%9B%9E%E3%80%82%3CBR%20%2F%3E%E6%AD%A3%E7%A1%AE%E7%9A%84%E5%81%9A%E6%B3%95%E6%98%AF%E4%BB%80%E4%B9%88%EF%BC%9F%3C%2FP%3E%3CP%3E%E8%B0%A2%E8%B0%A2%EF%BC%81%3C%2FP%3E%3CBR%20%2F%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1970996%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9AUSB%20CDC%20%E7%A4%BA%E4%BE%8B%E4%BB%85%E6%8E%A5%E6%94%B6%E5%A4%B1%E8%B4%A5%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1970996%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3EHi%2C%3C%2FP%3E%0A%3CP%3E%E6%98%AF%E7%9A%84%EF%BC%8C%E8%BF%99%E6%98%AF%E4%B8%80%E4%B8%AA%E5%BE%88%E5%A5%BD%E7%9A%84%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88%E3%80%82%E8%8E%B7%E5%BE%97%E6%95%B0%E6%8D%AE%E5%90%8E%EF%BC%8C%E5%8F%AA%E9%9C%80%E8%B0%83%E7%94%A8%E8%AF%A5%E5%87%BD%E6%95%B0%E5%8D%B3%E5%8F%AF%E5%8F%91%E9%80%81%E3%80%82%3C%2FP%3E%0A%3CP%3EBR%3C%2FP%3E%0A%3CP%3E%E8%8D%A3%E5%90%91%E5%86%9B%3C%2FP%3E%0A%3CPRE%20class%3D%22lia-code-sample%20language-c%22%3E%3CCODE%20translate%3D%22no%22%3EUSB_DeviceCdcAcmSend()%3B%3C%2FCODE%3E%3C%2FPRE%3E%0A%3CBR%20%2F%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1970007%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9AUSB%20CDC%20%E7%A4%BA%E4%BE%8B%E4%BB%85%E6%8E%A5%E6%94%B6%E5%A4%B1%E8%B4%A5%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1970007%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%90%91%3CSPAN%3E%E5%90%9B%E6%82%A8%E5%A5%BD%EF%BC%8C%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%3CSPAN%3E%E6%88%91%E4%BD%BF%E7%94%A8%E7%9A%84%E9%83%A8%E4%BB%B6%E6%98%AF%3C%2FSPAN%3E%E5%AE%9A%E5%88%B6%E6%9D%BF%E4%B8%AD%E7%9A%84%20MK27FN2M0VM115%EF%BC%8C%E4%BD%86%E6%88%91%E4%B9%9F%E5%9C%A8%20FRDM-K64F%20%E4%B8%AD%E5%AF%B9%E5%85%B6%E8%BF%9B%E8%A1%8C%E4%BA%86%E6%B5%8B%E8%AF%95%E3%80%82%3C%2FP%3E%3CP%3E%E6%88%91%E8%A7%A3%E5%86%B3%E4%BA%86%E9%83%A8%E5%88%86%E8%B0%83%E7%94%A8USB%E5%8F%91%E9%80%81%E5%87%BD%E6%95%B0%E6%8E%A5%E6%94%B6%E5%90%8E%E6%B2%A1%E6%9C%89%E6%95%B0%E6%8D%AE%E7%9A%84%E9%97%AE%E9%A2%98%EF%BC%9A%3C%2FP%3E%3CBR%20%2F%3E%3CPRE%20class%3D%22lia-code-sample%20language-c%22%3E%3CCODE%20translate%3D%22no%22%3E%20if%20(s_sendSize)%0A%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20uint32_t%20size%20%3D%20s_sendSize%3B%0A%0A%0A%09%09%09s_sendSize%20%20%20%20%3D%200%3B%0A%0A%20%20%20%20%20%20%20%20%20%20%20%20error%20%3D%20USB_DeviceCdcAcmSend(s_cdcVcom.cdcAcmHandle%2C%20USB_CDC_VCOM_BULK_IN_ENDPOINT%2C%20NULL%2C%200)%3B%0A%0A%20%20%20%20%20%20%20%20%20%20%20%20if%20(error%20!%3D%20kStatus_USB_Success)%0A%20%20%20%20%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%2F%2F%20Failure%20to%20send%20Data%20Handling%20code%20here%0A%20%20%20%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%20%7D%3C%2FCODE%3E%3C%2FPRE%3E%3CBR%20%2F%3E%3CP%3E%E6%9C%89%E6%B2%A1%E6%9C%89%E6%9B%B4%E5%A5%BD%E7%9A%84%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88%EF%BC%9F%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1969408%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9AUSB%20CDC%20%E7%A4%BA%E4%BE%8B%E4%BB%85%E6%8E%A5%E6%94%B6%E5%A4%B1%E8%B4%A5%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1969408%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3EHi%2C%3C%2FP%3E%0A%3CP%3E%E6%82%A8%E8%83%BD%E5%91%8A%E8%AF%89%E6%88%91%E4%BB%AC%E6%82%A8%E4%BD%BF%E7%94%A8%E7%9A%84%E9%9B%B6%E4%BB%B6%E7%BC%96%E5%8F%B7%E5%90%97%EF%BC%9F%3C%2FP%3E%0A%3CP%3EBR%3C%2FP%3E%0A%3CP%3E%E8%8D%A3%E5%90%91%E4%BF%8A%3C%2FP%3E%3C%2FLINGO-BODY%3E