C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
No.24180 の関連記事表示
ヒット / 7件
(1-7 を表示)
<<
0
>>
■24180
ntdll.dllで例外エラーが発生します
□投稿者/ さんた -
(2008/08/28(Thu) 21:25:23)
分類:[C/C++]
C++もWinsockも初心者です、よろしくお願いします。
現在、メールを受信するプログラムを作成しているのですが、
ちょっと負荷がかかると例外エラーで強制終了し、イベントビューワーのアプリケーションに
「エラー発生アプリケーション mail.exe、バージョン 0.0.0.0、
エラー発生モジュール ntdll.dll、バージョン 5.1.2600.2180、エラー発生アドレス 0x0001888f」
と出ていました。
ネットで調べてみるとntdll.dllにはメモリ系の脆弱性があるという情報と、WindowsUpdateで直るとあったのですが、
Windows2003をUpdateしても同様の現象が発生してしまいます。
プログラムはソケット監視を行い、アクセスがあるとスレッドを生成して、
スレッド内でPOP3アクセスを行い、受信したメールをODBCで登録するマルチスレッドプログラムです。
件数が少ないときは良いのですが、50件程度のメールを2度3度と受信していると上記エラーが発生してしまいます。
環境はWindowsXPとWindows2003でC++はGCC3.4.5でコンパイルしています。
使用しているソケットはwinsock2.0を指定しています。
回避策や代替案などありましたら、教えてください。
よろしくお願いします。
親記事 /過去ログ45より /
関連記事表示
削除チェック/
■24181
Re[1]: ntdll.dllで例外エラーが発生します
□投稿者/ れい -
(2008/08/28(Thu) 21:58:23)
■
No24180
(さんた さん) に返信
> 件数が少ないときは良いのですが、50件程度のメールを2度3度と受信していると上記エラーが発生してしまいます。
> 環境はWindowsXPとWindows2003でC++はGCC3.4.5でコンパイルしています。
> 使用しているソケットはwinsock2.0を指定しています。
>
> 回避策や代替案などありましたら、教えてください。
> よろしくお願いします。
示された情報だけだとなんとも言えません。
スレッドとかソケット周りでおかしなことをしていて
おかしなパラメーターでAPIを読んでるのではないか、と疑います。
ntdllがオカシイ可能性もありますが。
例外がおきる最小コードを示すとよいかと。
記事No.24180 のレス /過去ログ45より /
関連記事表示
削除チェック/
■24182
Re[1]: ntdll.dllで例外エラーが発生します
□投稿者/ NyaRuRu -
(2008/08/28(Thu) 23:11:55)
■
No24180
(さんた さん) に返信
> 「エラー発生アプリケーション mail.exe、バージョン 0.0.0.0、
> エラー発生モジュール ntdll.dll、バージョン 5.1.2600.2180、エラー発生アドレス 0x0001888f」
> と出ていました。
この部分だけを読めば ntdll.dll が何かの問題を持っているような気がしてくるかもしれませんが,実際には ntdll.dll の動作は正常という場合もあります.
現時点で ntdll.dll 絡みのエラーを疑いすぎるのはおすすめできません.
>回避策や代替案などありましたら、教えてください。
一例として,読み込み不能なメモリアドレス addr を ntdll.dll の関数に渡した場合を考えます.
この場合,不正なポインタへのアクセスは ntdll.dll の関数内で発生することになります.
問題はそんな不正なアドレスを渡した呼び出し側にあるのですが,例外が起きるのは実際にメモリアクセスを行ったときなので,例外発生箇所は ntdll.dll となります.このときの正しい対処は,不正なアドレスを渡している箇所を探して,それを修正する,です.
もちろん実際には他の原因でエラーが発生しているケースも考えられます.いまはまだ原因が分からないという状況だと思います.
記事No.24180 のレス /過去ログ45より /
関連記事表示
削除チェック/
■24191
Re[2]: ntdll.dllで例外エラーが発生します
□投稿者/ さんた -
(2008/08/29(Fri) 09:25:00)
れい さん
NyaRuRu さん
ご返信ありがとうございます。
ntdll.dllに脆弱性があると見て以来、思考が固まっていたようです。
>おかしなパラメーターでAPIを読んでるのではないか
>一例として,読み込み不能なメモリアドレス addr を ntdll.dll の関数に渡した場合を考えます.
そうですね、処理容量が小さいときはたまたま動いているだけの可能性もありますし、
まずはntdll.dllとは何者で、どの処理を実行したときに呼ばれるのかから追っていきます。
ありがとうございます。
記事No.24180 のレス /過去ログ45より /
関連記事表示
削除チェック/
■24201
Re[3]: ntdll.dllで例外エラーが発生します
□投稿者/ シャノン -
(2008/08/29(Fri) 10:42:54)
■
No24191
(さんた さん) に返信
> まずはntdll.dllとは何者で、どの処理を実行したときに呼ばれるのかから追っていきます。
ntdll というのは Windows の中核モジュールの一つで、Windows API から間接的に呼ばれます。
かなりの数の API が最終的に ntdll を何らかの形で呼ぶので、総当たりだと大変な時間がかかりそうです。
GCC でのデバッグ手法は知りませんが、エラー発生時のスタックトレースから原因個所を特定できないでしょうか。
記事No.24180 のレス /過去ログ45より /
関連記事表示
削除チェック/
■24324
Re[4]: ntdll.dllで例外エラーが発生します
□投稿者/ さんた -
(2008/09/01(Mon) 16:22:59)
■
No24201
(シャノン さん) に返信
>
> ntdll というのは Windows の中核モジュールの一つで、Windows API から間接的に呼ばれます。
> かなりの数の API が最終的に ntdll を何らかの形で呼ぶので、総当たりだと大変な時間がかかりそうです。
> GCC でのデバッグ手法は知りませんが、エラー発生時のスタックトレースから原因個所を特定できないでしょうか。
返答ありがとうございます。
ntdllがどんな物か大体わかりましたが、シャノンさんのおっしゃるとおり当たりの付けようが無いというのが、正直な感想です。
とりあえず、怪しそうなODBC使用箇所とソケット使用箇所を重点的に見直してみます。
記事No.24180 のレス /過去ログ45より /
関連記事表示
削除チェック/
■24351
Re[5]: ntdll.dllで例外エラーが発生します
□投稿者/ さんた -
(2008/09/02(Tue) 10:02:18)
回答してくださいました皆様、本当にありがとうございました。
色々と修正・改変を行っているうちに該当のエラーがでなくなりました。
どうやら、どこかでメモリアクセス違反を犯し、それがntdllでクラッシュしていた原因のようです。
ntdllの不具合報告を見つけてから、焦点がそっちにうつってしまい視野狭窄になっていたようです。
記事No.24180 のレス / END /過去ログ45より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-