打印

68013A端点EP6OUT的BULK写失败

[复制链接]
1948|6
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
wangpe|  楼主 | 2011-12-25 12:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
68013A端点EP6OUT的BULK写失败求助,急!!
易用专业的PCI、USB、LED方案正在对68013A采用slavefifo方式进行bulk读写操作
我用EP2做in端点,1024字节,2从缓冲
用EP6做OUT端点,512字节,4从缓冲

我写好了68013A的固件,用CYPRESS的开发工具能够进行实现正确的读写
现在正在用DS2.7写驱动,现在写的驱动,能够顺利读取EP2,却不能写入EP6从SLAVEfifo连接的FPGA端看slavefifo的状态,EP6对应的fifo一直是空的)!

搞固件就郁闷了很久了,好不容易把固件的写搞定,现在驱动又来整我。
沙发
langgq| | 2011-12-25 12:28 | 只看该作者
一般来说应该不是驱动的问题吧,驱动都是CY编好的应该不会错。

使用特权

评论回复
板凳
langgq| | 2011-12-25 12:29 | 只看该作者
你的代码能贴出来看看呢

使用特权

评论回复
地板
wangpe|  楼主 | 2011-12-25 12:29 | 只看该作者
------------------------------------
// USB30ioctl.h

#ifndef __USB30ioctl__h_
#define __USB30ioctl__h_

#define IOCTL_CTRL_READ  CTL_CODE(FILE_DEVICE_UNKNOWN, 0x800, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_CTRL_WRITE CTL_CODE(FILE_DEVICE_UNKNOWN, 0x801, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_BULK_READ  CTL_CODE(FILE_DEVICE_UNKNOWN, 0x802, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_BULK_WRITE CTL_CODE(FILE_DEVICE_UNKNOWN, 0x803, METHOD_BUFFERED, FILE_ANY_ACCESS)
#endif
------------------------------------
// USB30Device.h
....................................

        // Unit number for this device (0-9)
    ULONG                m_Unit;
    KUsbLowerDevice        m_Lower;
    KUsbInterface      m_Interface;
        // Pipe for USB endpoint 2 IN (address 0x82)
    KUsbPipe            m_Endpoint2IN;
        // Pipe for USB endpoint 6 OUT (address 0x6)
    KUsbPipe            m_Endpoint6OUT;
....................................

------------------------------------
// USB30Device.CPP

.............................
    #define m_buffer_size 1048592;
    #define USB_transfer_size 1024
    #define USB_WRITE_SIZE 512
............................

    m_Unit = Unit;
    m_Lower.Initialize(this, Pdo);
    m_Interface.Initialize(
                        m_Lower, //KUsbLowerDevice
        0,        //InterfaceNumber
        1,        //ConfigurationValue
        0        //Initial Interface Alternate Setting    );

    // Initialize each Pipe object
    m_Endpoint2IN.Initialize(m_Lower, 0x82, 1024);
    m_Endpoint6OUT.Initialize(m_Lower, 0x06, 512);

  .............................................
...............................................//批量读,每次1024字节

NTSTATUS USB30Device::USB30_BULK_READ(KIrp I)
{
    NTSTATUS status = STATUS_INSUFFICIENT_RESOURCES;
    t < < "Entering USB30_BULK_READ\n";
    PURB pUrb=NULL;
    USB_current_buffer=m_buffer1;

        pUrb = m_Endpoint2IN.BuildBulkTransfer(
            USB_current_buffer,  // Where data write to?
            USB_transfer_size,  // How much data to read?
            TRUE,        // direction (TRUE = IN)
            NULL        // Link to next URB);
if ( pUrb != NULL)
{
    pUrb->UrbBulkOrInterruptTransfer.TransferFlags =(USBD_TRANSFER_DIRECTION_IN | USBD_SHORT_TRANSFER_OK);

                  status = m_Endpoint2IN.SubmitUrb(pUrb, NULL, NULL,URB_mSecTimeOut);
    t < <"after send SubmitUrb ,status=" < <ULONG(status) < <"\n";
                      //返回0x00000000

            if ( status==0x00000000 )
            {
    dwBytesRead = pUrb->UrbBulkOrInterruptTransfer.TransferBufferLength;
            }
    delete pUrb;
                    pUrb = NULL;
}


    RtlCopyMemory((PUCHAR)Request_Buffer, (PUCHAR)m_buffer1,TotalRead);
                    I.Information() = TotalRead;

  return status;
}
////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////批量写,每次512字节
NTSTATUS USB30Device:: USB30_BULK_WRITE(KIrp I)
{    NTSTATUS status = STATUS_INSUFFICIENT_RESOURCES;

    t < < "Entering USB30_BULK_WRITE\n";
    // Declare a memory object
//    KMemory Mem(I.Mdl());
//    KMemory Mem( I.IoctlBuffer());

    Request_Buffer_char= (PUCHAR) I.IoctlBuffer();
    ULONG URB_mSecTimeOut=((PULONG)Request_Buffer_char)[0];

                    UCHAR WrData_Buf        =  Request_Buffer_char+4;
                    ULONG dwBytesSent = 0;
                    PURB pUrb2=NULL;

                  pUrb2 = m_Endpoint6OUT.BuildBulkTransfer(
            WrData_Buf,          // Where the data is from?
            USB_WRITE_SIZE,  // How much data to write?
            FALSE,        // direction (FALSE = OUT)
            NULL,        // Link to next URB
            FALSE,        
            NULL);
    t < < "Entering BuildBulkTransfer ok!\n";

    if ( pUrb2 != NULL)
    {
    // pUrb->UrbBulkOrInterruptTransfer.TransferFlags =
    //    (USBD_TRANSFER_DIRECTION_OUT | USBD_SHORT_TRANSFER_OK);
status = m_Endpoint6OUT.SubmitUrb(pUrb2, NULL, NULL,URB_mSecTimeOut);//
t < <"after send SubmitUrb ,status=" < <ULONG(status) < <"\n";
//返回0x00000102(超时!URB_mSecTimeOut设置为1000ms)


            if ( status==0x00000000 )
        
    {
              dwBytesSent = pUrb2->UrbBulkOrInterruptTransfer.TransferBufferLength;
    }


      delete pUrb2;
    pUrb2 = NULL;
               

}
        

                  I.Information() = dwBytesSent;
    Request_Buffer_char=NULL;
          return status;

}

使用特权

评论回复
5
wangzsa| | 2011-12-25 12:29 | 只看该作者
楼主是不是端点搞错了,我也使用这个啊,没有出现什么问题啊

使用特权

评论回复
6
wangpe|  楼主 | 2011-12-25 12:30 | 只看该作者
因为固件调试工具能够正常进行读写
所以就把问题放在驱动身上
晚上在DS27下把驱动翻了个遍

无果

在DS32下重新开发驱动

效果一样!

使用特权

评论回复
7
287075766| | 2011-12-26 12:05 | 只看该作者
驱动好像没什么问题,应该是你固件的问题,最好看看你端点的设置,还有就是设备描述符里面的设置啊,等等

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

938

主题

9837

帖子

2

粉丝