打印

BULK写失败求助

[复制链接]
523|14
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
zyf部长|  楼主 | 2016-9-25 21:43 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
68013A端点EP6OUT的BULK写失败求助,急!!
易用专业的PCI、USB、LED方案正在对68013A采用slavefifo方式进行bulk读写操作
我用EP2做in端点,1024字节,2从缓冲
用EP6做OUT端点,512字节,4从缓冲
沙发
小小猫咪| | 2016-9-25 21:43 | 只看该作者
检查下你的固件配置对不对

使用特权

评论回复
板凳
zyf部长|  楼主 | 2016-9-25 21:45 | 只看该作者
我写好了68013A的固件,用CYPRESS的开发工具能够进行实现正确的读写

使用特权

评论回复
地板
zwll| | 2016-9-25 21:46 | 只看该作者
那就检查应用软件这一端啊,是不是软件用的驱动和当前装的驱动不一样

使用特权

评论回复
5
chuxh| | 2016-9-25 21:47 | 只看该作者
搞固件就郁闷,驱动又来整你。。。。

使用特权

评论回复
6
zyf部长|  楼主 | 2016-9-25 21:47 | 只看该作者
是啊,从SLAVEfifo连接的FPGA端看slavefifo的状态,EP6对应的fifo一直是空的

使用特权

评论回复
7
司徒老鹰| | 2016-9-25 21:51 | 只看该作者
能看下你的代码吗?

使用特权

评论回复
8
zyf部长|  楼主 | 2016-9-25 21:51 | 只看该作者

------------------------------------
// 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;

}
......................................................

使用特权

评论回复
9
zyf部长|  楼主 | 2016-9-25 21:52 | 只看该作者

因为固件调试工具能够正常进行读写
所以就把问题放在驱动身上
在DS27下把驱动翻了个遍

无果

使用特权

评论回复
10
llljh| | 2016-9-25 21:52 | 只看该作者
在DS32下重新开发驱动 呢

使用特权

评论回复
11
zyf部长|  楼主 | 2016-9-25 21:54 | 只看该作者
效果一样!

郁闷!!!!!

使用特权

评论回复
12
dingy| | 2016-9-25 21:54 | 只看该作者
你用同一个驱动,官方的工具可以读写。
你自己写的程序就不行?那你看看官方的程序是怎么写的吧

使用特权

评论回复
13
pengf| | 2016-9-25 21:55 | 只看该作者
固件的问题!

初始化out端点EP6时候
只做了
SYNCDELAY;                      OUTPKTEND=0x86;
未加
    SYNCDELAY;      EP6BCH= 0x02;  
  SYNCDELAY;          EP6BCL = 0x00;  

这个就是不能写的根本原因

使用特权

评论回复
14
pengf| | 2016-9-25 21:55 | 只看该作者
I.Information() = dwBytesSent; 这里最好改成    I.Information() = 0;否则会造成死机,不过这个算小问题哈!

使用特权

评论回复
15
zyf部长|  楼主 | 2016-9-25 21:56 | 只看该作者
哦,那我就知道怎么回事了,多谢大家,结贴了哈

使用特权

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

本版积分规则

694

主题

7102

帖子

8

粉丝