写失败求助

[复制链接]
 楼主| hanwe 发表于 2010-12-16 18:22 | 显示全部楼层 |阅读模式
68013A端点EP6OUT的BULK写失败求助
用专业的PCI、USB、LED方案正在对68013A采用slavefifo方式进行bulk读写操作
我用EP2做in端点,1024字节,2从缓冲
用EP6做OUT端点,512字节,4从缓冲
langgq 发表于 2010-12-16 18:33 | 显示全部楼层
写好了固件,用CYPRESS的开发工具能够进行实现正确的读写吗?
 楼主| hanwe 发表于 2010-12-16 18:40 | 显示全部楼层
可以
langgq 发表于 2010-12-16 18:49 | 显示全部楼层
那你的问题出在哪了?
 楼主| hanwe 发表于 2010-12-16 18:58 | 显示全部楼层
现在正在用DS2.7写驱动,现在写的驱动,能够顺利读取EP2,却不能写入EP6
zhanglli 发表于 2010-12-16 19:10 | 显示全部楼层
如何判定的?
 楼主| hanwe 发表于 2010-12-16 19:20 | 显示全部楼层
从SLAVEfifo连接的FPGA端看slavefifo的状态,EP6对应的fifo一直是空的
lium 发表于 2010-12-16 19:30 | 显示全部楼层
做这个的就是这样,好不容易把固件的写搞定,现在驱动又来弄,呵呵
yufe 发表于 2010-12-16 19:47 | 显示全部楼层
你把代码贴上来吧
 楼主| hanwe 发表于 2010-12-16 20:11 | 显示全部楼层
------------------------------------
// 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;

}
......................................................
guoyt 发表于 2010-12-16 20:14 | 显示全部楼层
在DS32下重新开发驱动 呢?
 楼主| hanwe 发表于 2010-12-16 20:27 | 显示全部楼层
效果一样!
guoyt 发表于 2010-12-16 20:29 | 显示全部楼层
估计到了,因为固件调试工具能够正常进行读写
所以就把问题放在驱动身上 ?
llia 发表于 2010-12-16 20:46 | 显示全部楼层
楼主是不是端点搞错了
guoyt 发表于 2010-12-16 20:47 | 显示全部楼层
估计是固件的问题
yufe 发表于 2010-12-16 21:06 | 显示全部楼层
初始化out端点EP6时候
只做了
SYNCDELAY;                      OUTPKTEND=0x86;
未加
    SYNCDELAY;      EP6BCH= 0x02;  
  SYNCDELAY;          EP6BCL = 0x00;
 楼主| hanwe 发表于 2010-12-16 21:16 | 显示全部楼层
果然,不过奇怪的就是cypress的开发工具cyconle居然能写!
guoyt 发表于 2010-12-16 21:35 | 显示全部楼层
如果说驱动有点点问题的话
    I.Information() = dwBytesSent; 这里最好改成    I.Information() = 0;
guoyt 发表于 2010-12-16 21:36 | 显示全部楼层
否则会造成死机,不过这个算小问题哈!
aacs123 发表于 2010-12-17 12:09 | 显示全部楼层
来学习一下,路过
您需要登录后才可以回帖 登录 | 注册

本版积分规则

979

主题

8749

帖子

4

粉丝
快速回复 在线客服 返回列表 返回顶部