• <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>

            2015年7月23日

            今天用 Buildroot 編譯文件系統(tǒng)燒寫到開發(fā)板啟動(dòng)提示下面的錯(cuò)誤
            can't open /dev/ttyS0: No such file or directory
            can't open /dev/ttyS0: No such file or directory
            can't open /dev/ttyS0: No such file or directory
            can't open /dev/ttyS0: No such file or directory
            can't open /dev/ttyS0: No such file or directory
            can't open /dev/null: No such file or directory
            can't open /dev/null: No such file or directory
            can't open /dev/null: No such file or directory
            can't open /dev/null: No such file or directory
            can't open /dev/null: No such file or directory

            后面發(fā)現(xiàn)是內(nèi)核沒有選上 CONFIG_DEVTMPFS_MOUNT 的原因,配置上之后重新編譯內(nèi)核燒寫到開發(fā)板就可以避免這個(gè)問題了

            posted @ 2015-07-23 18:31 墨…… 閱讀(2180) | 評(píng)論 (0)編輯 收藏


            2013年7月11日

               有時(shí)候編譯 Emacs 時(shí)不想發(fā)圖形界面,因?yàn)橛貌坏剑梢杂靡韵旅顏磉M(jìn)行編譯:
                   
            make -DWITHOUT_X11 install clean

            or

            make WITHOUT_X11=set install clean

            posted @ 2013-07-11 17:22 墨…… 閱讀(456) | 評(píng)論 (0)編輯 收藏


            2013年5月14日

            在查閱Linux源碼時(shí),總是為函數(shù)或變量的查找跟蹤而煩惱,有了這篇文章之后,再也不用煩惱了:
            http://lifegoo.pluskid.org/wiki/EmacsCscope.html

            posted @ 2013-05-14 17:41 墨…… 閱讀(406) | 評(píng)論 (0)編輯 收藏


            2013年4月10日

            這幾天一直在調(diào)試atmel at91sam9x25的串口,用著用著總會(huì)導(dǎo)致Oops,Oops內(nèi)容如下:
            [ 1023.510000] Unable to handle kernel NULL pointer dereference at virtual address 00000000
            [ 1023.520000] pgd = c0004000
            [ 1023.520000] [00000000] *pgd=00000000
            [ 1023.520000] Internal error: Oops: 17 [#1]
            [ 1023.520000] last sysfs file: /sys/devices/virtual/misc/at91flash/dev
            [ 1023.520000] Modules linked in: at91flash at91gpio at91mc323 ds18b20 at91adc
            [ 1023.520000] CPU: 0    Tainted: G        W    (2.6.39 #35)
            [ 1023.520000] PC is at atmel_tasklet_func+0x104/0x690
            [ 1023.520000] LR is at atmel_tasklet_func+0x10/0x690
            [ 1023.520000] pc : [<c01a33ac>]    lr : [<c01a32b8>]    psr: 20000013
            [ 1023.520000] sp : c7825f58  ip : 60000093  fp : 00000000
            [ 1023.520000] r10: 00000006  r9 : 00000000  r8 : 0000000a
            [ 1023.520000] r7 : 00000000  r6 : c7824000  r5 : c78a2484  r4 : c03c0cb8
            [ 1023.520000] r3 : 0000004c  r2 : 0000004c  r1 : 60000013  r0 : 00000001
            [ 1023.520000] Flags: nzCv  IRQs on  FIQs on  Mode SVC_32  ISA ARM  Segment kernel
            [ 1023.520000] Control: 0005317f  Table: 27b40000  DAC: 00000017
            [ 1023.520000] Process ksoftirqd/0 (pid: 3, stack limit = 0xc7824270)
            [ 1023.520000] Stack: (0xc7825f58 to 0xc7826000)
            [ 1023.520000] 5f40:                                                       00000001 c7824000
            [ 1023.520000] 5f60: 00000100 0000000a 00000000 00000006 c7825f8c 00000000 00000001 c7824000
            [ 1023.520000] 5f80: 00000100 0000000a 00000006 c0045cf8 c03b995c c00461d8 c7aa6ae0 00000000
            [ 1023.520000] 5fa0: 60000093 00000000 c7824000 c0046274 00000013 00000000 00000000 c00462e0
            [ 1023.520000] 5fc0: 00000000 c7819f70 00000000 c00570e0 00000000 00000000 00000000 00000000
            [ 1023.520000] 5fe0: c7825fe0 c7825fe0 c7819f70 c0057060 c0030b14 c0030b14 ffffffff ffffffff
            [ 1023.520000] [<c01a33ac>] (atmel_tasklet_func+0x104/0x690) from [<c0045cf8>] (tasklet_action+0x84/0xe
            [ 1023.520000] [<c0045cf8>] (tasklet_action+0x84/0xe from [<c00461d8>] (__do_softirq+0x88/0x124)
            [ 1023.520000] [<c00461d8>] (__do_softirq+0x88/0x124) from [<c00462e0>] (run_ksoftirqd+0x6c/0x12
            [ 1023.520000] [<c00462e0>] (run_ksoftirqd+0x6c/0x12 from [<c00570e0>] (kthread+0x80/0x8
            [ 1023.520000] [<c00570e0>] (kthread+0x80/0x8 from [<c0030b14>] (kernel_thread_exit+0x0/0x
            [ 1023.520000] Code: 1a000002 e59f057c e59f157c ebfa3d49 (e5973000) 
            [ 1023.710000] ---[ end trace 786b41cd25d3b661 ]---
            [ 1023.710000] Kernel panic - not syncing: Fatal exception in interrupt
            [ 1023.720000] [<c0034b10>] (unwind_backtrace+0x0/0xe0) from [<c02a8af8>] (panic+0x50/0x170)
            [ 1023.720000] [<c02a8af8>] (panic+0x50/0x170) from [<c0032e00>] (die+0x184/0x1c4)
            [ 1023.730000] [<c0032e00>] (die+0x184/0x1c4) from [<c0035aa8>] (__do_kernel_fault+0x64/0x84)
            [ 1023.740000] [<c0035aa8>] (__do_kernel_fault+0x64/0x84) from [<c0035c7c>] (do_page_fault+0x1b4/0x1c
            [ 1023.750000] [<c0035c7c>] (do_page_fault+0x1b4/0x1c from [<c002a240>] (do_DataAbort+0x30/0x9
            [ 1023.760000] [<c002a240>] (do_DataAbort+0x30/0x98) from [<c002f86c>] (__dabt_svc+0x4c/0x60)
            [ 1023.770000] Exception stack(0xc7825f10 to 0xc7825f58)
            [ 1023.770000] 5f00:                                     00000001 60000013 0000004c 0000004c
            [ 1023.780000] 5f20: c03c0cb8 c78a2484 c7824000 00000000 0000000a 00000000 00000006 00000000
            [ 1023.790000] 5f40: 60000093 c7825f58 c01a32b8 c01a33ac 20000013 ffffffff
            [ 1023.790000] [<c002f86c>] (__dabt_svc+0x4c/0x60) from [<c01a33ac>] (atmel_tasklet_func+0x104/0x690)
            [ 1023.800000] [<c01a33ac>] (atmel_tasklet_func+0x104/0x690) from [<c0045cf8>] (tasklet_action+0x84/0xe8)
            [ 1023.810000] [<c0045cf8>] (tasklet_action+0x84/0xe8) from [<c00461d8>] (__do_softirq+0x88/0x124)
            [ 1023.820000] [<c00461d8>] (__do_softirq+0x88/0x124) from [<c00462e0>] (run_ksoftirqd+0x6c/0x128)
            [ 1023.830000] [<c00462e0>] (run_ksoftirqd+0x6c/0x128) from [<c00570e0>] (kthread+0x80/0x88)
            [ 1023.840000] [<c00570e0>] (kthread+0x80/0x88) from [<c0030b14>] (kernel_thread_exit+0x0/0x8)
            注意上述紅色的地方。
            下面就來顯示如何定位出出錯(cuò)代碼行:
            1.首先,編譯時(shí)打開complie with debug info選項(xiàng),步則如下
            make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi- menuconfig
            oops1.jpg 
            進(jìn)入 Kernel hacking
            oops2.jpg 
            選擇 Compile the kernel with debug info
            然后,保存,退出。
            接著 make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi-
            編譯, 等編譯完成。
            2.利用arm-none-linux-gnueabi-gdb 調(diào)試,如下:
            arm-none-linux-gnueabi-gdb vmlinux
            oops3.jpg 
            對(duì)應(yīng)著Oops 消息里面的這一行
            [ 1023.520000] LR is at atmel_tasklet_func+0x10/0x690
            在gdb下鍵入命令 : l *at atmel_tasklet_func+0x10
            oops4.jpg 
            這樣就找到了出錯(cuò)的代碼行。在這里鄙視一下atmel提供的內(nèi)核,竟然還有bug,fuck it!
            從這里可以看出是由于串口的dma導(dǎo)致Oops的,于是我去掉了串口的dma傳輸。方法如下:
            oops5.jpg 
            去掉之后還沒有發(fā)現(xiàn)上述的Oops出現(xiàn)。

            以上來自: 
            http://bbs.chinaunix.net/thread-3744197-1-1.html

            用以上的方法也能解決 Oops,但我發(fā)現(xiàn)我的情況是有的串口收發(fā)都可以使用 DMA,而有的就不行,于是我一個(gè)一個(gè)串口的測試,修改源碼,將不能使用DMA的串口的DMA功能關(guān)閉掉,而不是將所有串口的 DMA 功能都關(guān)閉。


            posted @ 2013-04-10 15:16 墨…… 閱讀(993) | 評(píng)論 (0)編輯 收藏


            2013年4月2日

            編譯 scull

               出現(xiàn)以下錯(cuò)誤
             Fix it to use ccflags-y.  Stop.
               將 Makefile 中的 CFLAGS 改為 ccflags-y, 重新 make,又出現(xiàn)錯(cuò)誤
            main.c:15:26: fatal error: linux/config.h: No such file or directory
               將 main.c 中的 #include <linux/config.h> 刪除或注釋掉,重新 make,繼續(xù)編譯會(huì)遇到如下問題
            main.c:634:2: error: unknown field 'ioctl' specified in initializer
               是因?yàn)閮?nèi)核中的 file_operations 結(jié)構(gòu)發(fā)生了改變,將 main.c 中 scull_fops 聲明處的 .ioctl 改為 .unlocked_ioctl  即可,繼續(xù)編譯還會(huì)遇到如下問題
            main.c:652:3: error: implicit declaration of function ‘init_MUTEX’ [-Werror=implicit-function-declaration]
               可在 main.c 的開始處添加以下代碼解決問題
            #include <linux/semaphore.h>
            #define init_MUTEX(a) sema_init(a,1)
            #define init_MUTEX_LOCKED(a) sema_init(a,0)
               到這時(shí)還沒完,我開始有點(diǎn)煩燥了...繼續(xù)前進(jìn)時(shí)還出現(xiàn)以下錯(cuò)誤
            pipe.c: In function ‘scull_p_read’:
            pipe.c:131:7: error: ‘TASK_INTERRUPTIBLE’ undeclared (first use in this function)
            pipe.c:131:7: note: each undeclared identifier is reported only once for each function it appears in
            pipe.c:131:3: error: implicit declaration of function ‘signal_pending’ [-Werror=implicit-function-declaration]
            pipe.c:131:3: error: implicit declaration of function ‘schedule’ [-Werror=implicit-function-declaration]
               該問題可向 pipe.c 和 access.c 中添加 #include <linux/sched.h> 來解決,但后面還會(huì)遇到這樣的問題
            access.c:101:34: error: ‘SPIN_LOCK_UNLOCKED’ undeclared here (not in a function)
               在access.c文件中用 static DEFINE_SPINLOCK(scull_w_lock);  來代替 static spinlock_t scull_w_lock = SPIN_LOCK_UNLOCKED;
               繼續(xù)進(jìn)行,遭遇下面問題
            access.c:111:29: error: ‘struct task_struct’ has no member named ‘uid’
            access.c:112:29: error: ‘struct task_struct’ has no member named ‘euid’
            access.c:119:26: error: ‘struct task_struct’ has no member named ‘uid’
               把 access.c 文件中的 
            current->uid 
            current->euid
               全部修對(duì)應(yīng)地改為
            current->cred->uid
            current->cred->euid
               繼續(xù)重新 make,終于可以生成 scull.ko 了,OMG......

               還要注意的是,上面的錯(cuò)誤可能不止發(fā)生在一個(gè)地方,編譯時(shí)需要注意看清錯(cuò)誤提示,如果有跟上面一樣的錯(cuò)誤發(fā)生,只需參照上面的方法來修改即可。
               驅(qū)動(dòng)不會(huì)在虛擬終端上輸出,所以如果在終端上沒看到驅(qū)動(dòng)的輸出,可以看看是不是輸出到日志中了:
            /var/log/syslog


            Contact us

            posted @ 2013-04-02 15:36 墨…… 閱讀(912) | 評(píng)論 (0)編輯 收藏


            2012年5月1日

            一:查詢出所有表的鍵


            SELECT * FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE TABLE_NAME='you tableName'


            二:查詢出所有的外鍵


            select * from 
            (
               
            SELECT * FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE 
               
            WHERE TABLE_NAME='Data_Product'
            ) tableTemp
            where  CONSTRAINT_NAME like 'FK%'

            另外表的類型有  'C', 'F', 'PK', 'UQ', 'D'  可以按鍵需要來修改
            轉(zhuǎn)載自http://www.diybl.com/course/7_databases/mysql/Mysqljs/20090415/165077.html

            posted @ 2012-05-01 16:37 墨…… 閱讀(1316) | 評(píng)論 (0)編輯 收藏


            2012年4月15日

                MFC 的 cdatetimectrl 的控件有時(shí)在剛開始的時(shí)候顯示時(shí)間默認(rèn)為 1970
                問題有可能在于給 cdatetimectrl 控件關(guān)聯(lián)了一個(gè) CTIME 變量,該變量在構(gòu)造函數(shù)里初始化為 0,就會(huì)導(dǎo)致該控件初始顯示為 1970 或 08:00:00
                解決方法是將構(gòu)造函數(shù)里的初始化刪掉,控件就會(huì)顯示當(dāng)前打開的時(shí)間

            posted @ 2012-04-15 16:32 墨…… 閱讀(649) | 評(píng)論 (0)編輯 收藏


            2012年3月9日

            在一個(gè)項(xiàng)目的調(diào)試過程中,出現(xiàn)錯(cuò)誤

            debug assertion failed, file:dlgdata.cpp,line"43

            經(jīng)網(wǎng)上查找,項(xiàng)目查證:

            問題原因:沒有找到這個(gè)相應(yīng)控件類型 !
                   一般有三種情況:一是控件ID不存在,二是控件未創(chuàng)建,三是控件的類型不對(duì) 
            看看DoDataExchange函數(shù) 

                    我遇到這種情況原因是控件ID不對(duì)。。

            轉(zhuǎn)載自:http://www.cnblogs.com/wenbin/archive/2009/05/07/1452188.html

            posted @ 2012-03-09 15:58 墨…… 閱讀(1668) | 評(píng)論 (0)編輯 收藏


            僅列出標(biāo)題  

            posts - 8, comments - 0, trackbacks - 0, articles - 0

            Copyright © 墨……

            久久人人爽人人爽人人片AV不| 久久91亚洲人成电影网站| 欧美精品国产综合久久| 天天躁日日躁狠狠久久| 91精品国产高清久久久久久91| 久久这里的只有是精品23| 国产高潮国产高潮久久久| 四虎亚洲国产成人久久精品| 国内精品久久久久伊人av| 色偷偷88欧美精品久久久| 996久久国产精品线观看| 伊人久久精品影院| 99久久成人国产精品免费| 性高湖久久久久久久久AAAAA| 久久精品国产亚洲AV大全| 亚洲va久久久久| 久久精品国产亚洲Aⅴ香蕉| 久久国产色AV免费观看| 91麻豆国产精品91久久久| 久久精品国产清自在天天线| 久久不见久久见免费视频7| 亚洲精品国产自在久久| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 国产一久久香蕉国产线看观看| 性做久久久久久久久久久| 一本久久久久久久| 久久免费高清视频| 国产午夜精品理论片久久影视| 无码人妻久久久一区二区三区| 亚洲午夜久久久| 欧美久久久久久午夜精品| 伊人久久综合热线大杳蕉下载| 久久久精品国产sm调教网站| 亚洲女久久久噜噜噜熟女| 久久99久久99精品免视看动漫 | 久久99精品久久久久子伦| 免费精品久久天干天干| 久久这里的只有是精品23| 无码国内精品久久人妻麻豆按摩| 久久久久99精品成人片三人毛片| 久久国产精品二国产精品|