• <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>
            aurain
            技術(shù)文摘
            posts - 137,  comments - 268,  trackbacks - 0

                 今天在調(diào)試驅(qū)動的時候,發(fā)現(xiàn)一個開始覺得很奇怪的問題,就是調(diào)用RtlStringCbPrintfW函數(shù)來格式化WCHAR字符串時,一定藍(lán)屏,提示
            IRQL_NOT_LESS_OR_EQUAL,并且比較郁悶的是,在虛擬機上有時不會出現(xiàn),有時會出現(xiàn),但在真正的主機上一定會出現(xiàn)(Windows xp sp2)。
            一般出現(xiàn)IRQL_NOT_LESS_OR_EQUAL,是IRQL在級別高的地方調(diào)用了分頁內(nèi)存,所以,我就想到把當(dāng)前的IRQL打出來看看,發(fā)現(xiàn)在進入函數(shù)
            的時候,當(dāng)前的IRQL是0(PASSIVE_LEVEL),而在執(zhí)行這段代碼的地方,IRQL是2(DISPATCH_LEVEL),是什么原因使得IRQL發(fā)生了變化呢?
            仔細(xì)查看代碼后,發(fā)現(xiàn)了原因,因為在執(zhí)行這段代碼之前,通過NdisAcquireSpinLock獲取旋轉(zhuǎn)鎖,而在旋轉(zhuǎn)鎖釋放之前,其中的代碼是跑在
            IRQL=2的,另外,RtlStringCbPrintfW需要處理分頁內(nèi)存(PagedPool),但在IRQL=2的情況下,是只能處理非分頁內(nèi)存的(NonpagedPool),所以,
            就產(chǎn)生了上面的藍(lán)屏現(xiàn)象。

            這里給出驅(qū)動內(nèi)存的分配細(xì)節(jié):
            驅(qū)動編程時,也有兩種申請內(nèi)存的方式:
            (1).在核心棧中申請,在X86 R0級中,核心棧只有約兩個頁面的大小,所以DDK中提到,不能使用遞歸調(diào)用。
            (2).在核心堆中申請,比如ExAllocatePoolWithTag函數(shù)就可以。不過核心堆分成兩種:分頁的、非分頁的。

            另外,獲取當(dāng)前IRQL級別方法:
             KIRQL uIrql = KeGetCurrentIrql();
             DEBUG_INFO(("%s is run on level: %x\n", __FUNCTION__, uIrql));

            posted on 2009-01-14 17:05 閱讀(5034) 評論(0)  編輯 收藏 引用 所屬分類: windows驅(qū)動

            <2009年1月>
            28293031123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(17)

            隨筆分類(138)

            隨筆檔案(137)

            網(wǎng)絡(luò)開發(fā)

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 498999
            • 排名 - 36

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲AV无码久久精品蜜桃| 一本久久a久久精品vr综合| 亚洲AV无码久久精品色欲| 7777精品久久久大香线蕉| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 2022年国产精品久久久久| 久久精品国产精品青草app| 久久综合色区| 久久久av波多野一区二区| 青青青国产精品国产精品久久久久| 久久久久亚洲AV综合波多野结衣| 久久青青草视频| 99久久精品免费观看国产| 久久久久亚洲AV成人网人人网站 | 93精91精品国产综合久久香蕉| 色婷婷久久久SWAG精品| 国产成人久久精品麻豆一区| 久久婷婷激情综合色综合俺也去| 国产精品久久久久久久久久影院| 99久久www免费人成精品| 2021国产精品午夜久久| 国产成人精品久久综合| 国产精品国色综合久久| 蜜臀av性久久久久蜜臀aⅴ麻豆| 免费观看久久精彩视频| 人妻无码αv中文字幕久久| 亚洲第一永久AV网站久久精品男人的天堂AV| 狠狠色综合网站久久久久久久高清 | 伊人久久大香线蕉AV色婷婷色| 国产亚州精品女人久久久久久| 久久久综合九色合综国产| 色综合久久久久综合体桃花网| 久久久久一级精品亚洲国产成人综合AV区| 99久久综合狠狠综合久久止| AV无码久久久久不卡蜜桃| 青青热久久国产久精品| 久久国产成人精品国产成人亚洲| 国产精品久久波多野结衣| 狠狠干狠狠久久| 久久电影网一区| 99久久精品无码一区二区毛片 |