• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 298  文章 - 377  trackbacks - 0
            <2013年6月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            常用鏈接

            留言簿(34)

            隨筆分類

            隨筆檔案

            文章檔案

            相冊(cè)

            收藏夾

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            記錄一下解決EZ6410的板子在Linux下用USB來傳輸文件問題的過程~

            前兩天ARM11的開發(fā)板到了,需要先驗(yàn)證一下各項(xiàng)功能。以往用FS2410時(shí)用的是minicom+usb2ram,功能比windows下的dnw更強(qiáng),因?yàn)閙inicom支持彩色顯示,不會(huì)像dnw一樣出現(xiàn)很多亂碼,這一點(diǎn)上超級(jí)終端做的也不錯(cuò),可惜不能支持USB傳輸,加上我們用的是Linux嵌入式系統(tǒng),平時(shí)開發(fā)都在Ubuntu下進(jìn)行,當(dāng)然選擇minicom+usb2ram了~

            不過這次出問題了,usb2ram不支持EZ6410板子的USB傳輸,這讓我很郁悶!查看usb2ram的源代碼,發(fā)現(xiàn)里面主要有四個(gè)地方和具體的板子相關(guān),分別是vendorID,productID,ram_base和EndPoint地址。問題隨之變?yōu)槿绾尾榭碋Z6410開發(fā)板上這些參數(shù)的具體值了。ram_base很簡單,使用手冊(cè)里就有,0x50200000。其他三個(gè)上網(wǎng)搜了一下,發(fā)現(xiàn)用lsusb可以列出來前兩個(gè),分別為0x04e8和0x1234,至于EndPoint地址本來為0x03,我試著改為0x02就可以了~

            編譯通過后,可以配合minicom使用了,不過速度還是偏慢,尤其是和Windows下的DNW對(duì)比,慢得和蝸牛一樣!于是我又上網(wǎng)搜Linux下和DNW相似的USB傳輸程序,還真讓我發(fā)現(xiàn)了一個(gè),叫做dnw2。

            很簡單,就一個(gè)c文件,打開看源代碼,是支持QQ2440的,結(jié)構(gòu)比usb2ram更加清晰簡單,要改的就三個(gè)地方,vendorID,productID和ram_base,不需要EndPoint了,更確切的說是已經(jīng)固定為0x02了~我把三個(gè)宏定義設(shè)置好,編譯通過后試了一下,可以支持,并且速度明顯比usb2ram快了很多,和Windows下的DNW沒有直接對(duì)比,還不好說,不過估計(jì)也差不多了~

            有了dnw2,估計(jì)以后就不需要usb2ram了,畢竟速度上差了很多,沒有人會(huì)喜歡慢的東西嘛~

            ps,dnw2.c的源代碼

            C語言: Linux下通過USB傳輸文件到RAM中用的dnw2

            /* dnw2 linux main file. This depends on libusb.
            *
            * You should use lsusb to find out the actual vender ID & product ID of board.
            *
            * Author:     Fox <hulifox008@163.com>
            *             Ace Strong <acestrong@gmail.com>
            * License:    GPL
            *
            */

            #include 
            <stdio.h>
            #include 
            <usb.h>
            #include 
            <errno.h>
            #include 
            <sys/stat.h>
            #include 
            <fcntl.h>
            #include 
            <unistd.h>

            #define QQ2440_VENDOR_ID        0x5345
            #define QQ2440_PRODUCT_ID       0x1234
            #define FS2410_VENDOR_ID        0x5345
            #define FS2410_PRODUCT_ID       0x1234
            #define EZ6410_VENDOR_ID        0x04e8
            #define EZ6410_PRODUCT_ID       0x1234

            #define EZ6410_RAM_BASE         0x50200000
            #define FS2410_RAM_BASE         0x30200000

            /*
            // FS2410
            #define RAM_BASE            FS2410_RAM_BASE
            #define VENDOR_ID           FS2410_VENDOR_ID
            #define PRODUCT_ID          FS2410_PRODUCT_ID
            */
            // EZ6410
            #define RAM_BASE            EZ6410_RAM_BASE
            #define VENDOR_ID           EZ6410_VENDOR_ID
            #define PRODUCT_ID          EZ6410_PRODUCT_ID

            struct usb_dev_handle * open_port()
            {
                
            struct usb_bus *busses, *bus;

                usb_init();
                usb_find_busses();
                usb_find_devices();

                busses 
            = usb_get_busses();
                
            for(bus=busses;bus;bus=bus->next)
                {
                    
            struct usb_device *dev;
                    
            for(dev=bus->devices;dev;dev=dev->next)
                    {
                        
            if( VENDOR_ID==dev->descriptor.idVendor
                        
            &&  PRODUCT_ID==dev->descriptor.idProduct)
                        {
                            printf(
            "Target usb device found!\n");
                            
            struct usb_dev_handle *hdev = usb_open(dev);
                            
            if(!hdev)
                            {
                                perror(
            "Cannot open device");   
                            }
                            
            else
                            {
                                
            if(0!=usb_claim_interface(hdev, 0))
                                {
                                    perror(
            "Cannot claim interface");
                                    usb_close(hdev);
                                    hdev 
            = NULL;
                                }
                            }
                            
            return hdev;
                        }
                    }
                }
               
                printf(
            "Target usb device not found!\n");

                
            return NULL;
            }

            void usage()
            {
                printf(
            "Usage: dnw2 <file>\n\n");
            }

            unsigned 
            char* prepare_write_buf(char *filename, unsigned int *len)
            {
                unsigned 
            char *write_buf = NULL;
                
            struct stat fs;

                
            int fd = open(filename, O_RDONLY);
                
            if(-1==fd)
                {
                    perror(
            "Cannot open file");
                    
            return NULL;
                }
                
            if(-1==fstat(fd, &fs))
                {
                    perror(
            "Cannot get file size");
                    
            goto error;
                }
                write_buf 
            = (unsigned char*)malloc(fs.st_size+10);
                
            if(NULL==write_buf)
                {
                    perror(
            "malloc failed");
                    
            goto error;
                }

                
            if(fs.st_size != read(fd, write_buf+8, fs.st_size))
                {
                    perror(
            "Reading file failed");
                    
            goto error;
                }

                printf(
            "Filename : %s\n", filename);
                printf(
            "Filesize : %d bytes\n", fs.st_size);

                
            *((u_int32_t*)write_buf) = RAM_BASE;        //download address
                *((u_int32_t*)write_buf+1= fs.st_size + 10;    //download size;

                
            *len = fs.st_size + 10;
                
            return write_buf;

            error:
                
            if(fd!=-1) close(fd);
                
            if(NULL!=write_buf) free(write_buf);
                fs.st_size 
            = 0;
                
            return NULL;
               
            }

            int main(int argc, char *argv[])
            {
                
            if(2!=argc)
                {
                    usage();
                    
            return 1;
                }

                
            struct usb_dev_handle *hdev = open_port();
                
            if(!hdev)
                {
                    
            return 1;
                }

                unsigned 
            int len = 0;
                unsigned 
            char* write_buf = prepare_write_buf(argv[1], &len);
                
            if(NULL==write_buf) return 1;

                unsigned 
            int remain = len;
                unsigned 
            int towrite;
                printf(
            "Writing data \n");
                
            while(remain)
                {
                    towrite 
            = remain>512 ? 512 : remain;
                    
            if(towrite != usb_bulk_write(hdev, 0x02, write_buf+(len-remain), towrite, 3000))
                    {
                        perror(
            "usb_bulk_write failed");
                        
            break;
                    }
                    remain
            -=towrite;
                    printf(
            "\r%d%\t %d bytes     ", (len-remain)*100/len, len-remain);
                    fflush(stdout);
                }
                
            if(0==remain) printf("Done!\n");
                
            return 0;
            }
            posted on 2015-05-03 23:49 聶文龍 閱讀(1079) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            国产福利电影一区二区三区,免费久久久久久久精 | 国产精品美女久久福利网站| 香蕉99久久国产综合精品宅男自 | 久久久久人妻一区精品色| 精品久久一区二区| 亚洲国产精品综合久久一线| 久久人人爽人人爽人人AV| 久久精品国产一区二区| 国内精品人妻无码久久久影院导航| 久久九九亚洲精品| 亚洲va久久久噜噜噜久久天堂| 久久精品无码一区二区日韩AV| 99久久无色码中文字幕| 久久婷婷色香五月综合激情| 精品视频久久久久| 久久免费精品视频| 久久久噜噜噜久久中文福利| 国产69精品久久久久APP下载| 国内精品久久久久影院网站| 国产精品久久久天天影视| 欧洲精品久久久av无码电影| 99精品国产99久久久久久97| 中文字幕精品久久| 久久免费视频1| 伊人 久久 精品| 久久久精品国产| 国产69精品久久久久APP下载| 无码人妻少妇久久中文字幕 | 久久综合噜噜激激的五月天| 久久天天躁夜夜躁狠狠| 97精品伊人久久大香线蕉| 久久婷婷五月综合成人D啪| 国产精品99久久久精品无码| 久久久久亚洲爆乳少妇无| 国产午夜福利精品久久2021| 色综合久久中文色婷婷| 伊人久久无码中文字幕| 无码人妻久久一区二区三区免费 | 亚洲第一永久AV网站久久精品男人的天堂AV | 久久狠狠色狠狠色综合| 日本道色综合久久影院|