부모글 보이기/감추기 AD BLOCK 해제 요청 이 글에는 광고가 많이 들어가 있지 않습니다. adblock을 해제하셔도 글을 읽는데 그다지 부담이 없으니 해제를 부탁드립니다. WinDbg로 커널 디버깅 시 thread를 freeze 시키는 방법이 있을까요? 커널 디버깅이 아니라면 다음( https://docs.microsoft.com/en-us/windows-hardware/drivers/debugger/-f--freeze-thread- )과 같은 명령어도 있는 것 같습니다만.. 대체적인 방법으로 breakpoint를 걸고 `eb fe(JMP TO SELF)`로 코드 패치하여 무한 루프를 돌게한 후에 다시 작업이 끝나면 코드를 원상복귀 시키는 방법을 쓰려고 했지만, 이렇게 할 경우 오버헤드가 크게 발생하는 것 같습니다. [다음 글] 안녕하세요 생성자 호출 시 초기화 순서 질문드립니다[이전 글] WMI 쿼리 결과값이 Windows Service와 Console 출력에서 상이한 이유가 있을까요? [최초 등록일: 8/26/2022] [최종 수정일: 8/26/2022] 비밀번호 댓글 작성자 2022-08-26 03시57분 Inside Windows Debugging 책에도 커널 모드에서의 스레드를 eb fe로 제어하는 것을 소개하고 있는 걸로 봐서는 딱히 windbg에서 제공하는 명령어는 없는 것 같습니다. (공식 문서에 없으니.)그 외 다른 의견을 보면 user-mode 디버거와 연동하라고 하는데, 이건 Kernel에서 생성한 System Thread에 대해서는 통하지 않는 문제가 있습니다.저도 해보진 않았지만... 어차피 SuspendThread의 동작을 그대로 해주면 안 될까요? 일단은, _KTHREAD의 SuspendCount를 올려주면 될 듯하고, 문제는 SuspendSemaphore 필드인데... 그걸 수작업 구성해서 OS에 인식시키는 것이 바이트 패치만으로는 어려울 듯하니, 그런 작업을 대행하는 kernel driver를 만들어야 할 것입니다.혹시, 성공하시게 되면 후기 좀 들려주세요. ^^그나저나, 처음에는 왜 커널 모드에서 스레드 제어 기능을 제공하지 않는지 이해가 안 되었는데, 답변을 하다 보니 수긍이 됩니다. 따지고 보면, windbg가 커널 메모리를 읽거나 쓰는 정도의 기능을 제공하는 것이므로 OS가 멈춘 상태에서 kernel API를 호출할 수는 없으므로 user-mode처럼 스레드를 중지/재시작하는 기능을 갖출 수는 없었을 것 같습니다. 정성태 2022-08-26 05시46분 [ilililililll] 종합적으로 바라볼 수 있게 되었네요.. 역시 공식 문서에 없는 것은 이유가 있었군요 감사합니다! 방법을 찾아보겠습니다 성공하면 공유드리겠습니다:) [guest] 1 [2] 3 4 5 6 7 8 9 10 11 12 13 14 15 ... NoWriterDateCnt.TitleFile(s) 5939괴물신인7/9/20248429템플릿 대체할수있는방법이 있을까요? [6]5938씨제바보7/5/20247267책 질문드립니다. [1]5937Thor... 5/27/20248513C# 12 는 전자책이 언제쯤 나오게 될까요? [1]5936ds4/26/20249479활성화 되어 있는 커뮤니티 발견하게 되어 기분이 좋습니다. 자주 놀러 올께요. (내용 없습니다. [2]5935양승조 4/25/20249449Reflection 관련 질문 드립니다. [5]15934양승조 4/24/20248289Reflection 관련 질문 드립니다. [1]5933vict...4/23/20248307cpp 라이브러리 디버깅 방법 문의 드립니다. [1]5932EK4/12/20248285다음 제네릭에서 널익셉션이 뜨는 이유를 알수있을까요? [1]5931이대희4/2/20248879Windows 앱 SDK C# 템플릿의 용도가 무엇인지요? [1]5930vict...2/22/202410196ef core, FromSqlRaw 맵핑 질문입니다. [4]5929a2/17/20249427.Net 8 에서 디버거 변경 [1]5928vict...2/5/202410658wpf에서 대량 데이터 보여주는 방법 추천 부탁드립니다. [1]5926엄태영1/12/202410920잘못된 Task 사용으로 인한 데드락 관련 질문 입니다. [3]5925Euni...12/22/20239896Visual Studio에서 nodejs 사용시 npm install -g @vue/cli 실행시 오류 [1]5924Euni...12/21/202310286Visual Studio에서 nodejs 사용시 C:\Program Files\nodejs\\node.exe" "C:\Program Files\nodejs\\node_modules\npm\bin\npm-cli.js" prefix -g 를 찾지 못하는 설치 오류 [2]5923정두호12/4/202310381MSSQL 데이터 전송과 공유폴더의 데이터 전송 차이점 [1]5922Heeg...10/27/202312517C++의 double pointer를 C#에서 구현하는 방법이 잘 안됩니다. [3]5921한예지 10/3/202312336마샬링 정의 및 목적이 궁금합니다. [5]5920한예지 10/3/202311603C#과 WIN32 API 관계 질문드립니다. [4]5919이건우9/27/202310784WinForm의 로딩속도 관련 질문입니다 [2]5917한예지 9/14/202311064동기화 도구 질문 있습니다. [4]5916한예지 9/3/202311395Thread.Sleep(500), await Task.Delay(500), Task.Delay(500) 차이점이 궁금합니다. [2]5915한예지 8/30/202311957비동기 코드를 for 문 안에 작성한 경우 제어 변수가 올바르게 동작하지 않는 이유가 궁금합니다. [3]5914한상욱8/11/202311702.net wpf에서 skiasharp 의 skelement 를 canvas로 사용 하고 있습니다. [1]5913김태우8/10/202311457지역변수로 이해하는 메서드매개변수 게시글 댓글 [3]5912guest4/25/202316758[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3] 1 [2] 3 4 5 6 7 8 9 10 11 12 13 14 15 ...