Microsoft MVP성태의 닷넷 이야기
기타: 27. D820 - A09 바이오스 업데이트 프로그램 패치 [링크 복사], [링크+제목 복사],
조회: 22134
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

D820 - A09 바이오스 업데이트 프로그램 패치


... 를 공개한다는 것은 아니고요. ^^; 왜냐하면, 그런 "변조된" 프로그램을 무단으로 배포하는 것에 대해서 법적인 문제가 발생할 수도 있고, 어찌되었건 그 방식이 Dell의 공식적인 권장 사항이 아니기 때문에 패치된 파일을 공개하는 것은 좀 무리가 있는 듯합니다.

일단, 실행 시에 해당 프로세스를 디버깅하는 것으로 해결하는 방법은 아래의 글에서 예전에 공개해 드렸지요.

D820 - 배터리 없이 바이오스 업데이트 방법
; https://www.sysnet.pe.kr/2/0/632

오늘 처음으로 위의 글과 관련해서 패치 파일을 요청하신 분이 계셔서.
그런 분들을 위해 직접 패치 파일을 만드는 방법을 알려드리려는 것이 이번 글의 목적입니다. (또는, 자신이 안 되면 주변 분들에게라도 부탁하시거나. ^^)

사실, 바이너리 편집기로 특정 기계어 코드만 편집하면 되기 때문에 그다지 어려운 것은 아닙니다.

일단, D820_A09.exe 파일을 Visual Studio에서 열기 메뉴로 아래와 같이 "Open With"의 "Binary Editor"를 선택해서 읽어냅니다.

[그림 1: Open With Binary Editor]
how_to_do_d820_a09_bios_patch_1.PNG

그런 후, "E8 4F 07 00 00 85 C0"을 검색합니다. 이 바이트 코드들은 "00420D67" 번지와 "00420D6C" 번지의 기계어 코드 값들입니다.

00420D67 E8 4F 07 00 00   call        004214BB 
00420D6C 85 C0            test        eax,eax 
00420D6E 89 44 24 10      mov         dword ptr [esp+10h],eax 

[그림 2: "E8 4F 07 00 00 85 C0" 기계어 코드]
how_to_do_d820_a09_bios_patch_2.PNG

자... 이제 선택을 해야 하는데요. "test eax, eax"에 대한 기계어 코드가 "85 C0"인데, 이렇게 2byte를 유지하면서 위의 기능을 은근슬쩍 넘어갈 만한 코드가 어떤게 있을까요?

제 생각으로는,,, 그나마 "cmp eax, eax" - "33 C0"의 조합이 괜찮은 것 같은데요. ^^ 그래서, 85 값을 33으로 바꿔준 후 저장합니다.

이제 실행하면 끝!



[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/25/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2013-05-03 07시42분
[Lyn] 이럴땐 근야 nop 연타가 (...)
[guest]
2013-05-03 08시21분
그러면 문제가 발생하지 않을까요? ^^ nop으로 해버리면 ZF가 셋팅되지 않을 거라서 JE 점프문이 동작 안하기 때문에, CMP eax, eax로 해준 것입니다.
정성태

... 166  167  168  169  170  171  [172]  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
701정성태4/17/200926972Windows: 44. bootsect 오류 - Access is denied.
700정성태4/17/200930063.NET Framework: 129. Infragistics WPF 컨트롤 사용 [1]
699정성태4/16/200928610.NET Framework: 128. 이벤트 멤버의 명시적 구현파일 다운로드1
696정성태4/12/200927834오류 유형: 77. RDP 연결이 되지 않는 경우. [1]
693정성태4/9/200922324오류 유형: 76. "Client found response content type of '', but expected 'text/xml'. The request failed with an empty response.No Reports".
692정성태4/8/200935314.NET Framework: 127. ClickOnce로 ActiveX를 같이 배포하는 방법 [2]파일 다운로드1
690정성태4/5/200922895오류 유형: 75. Event Viewer - The data is invalid (13)
688정성태4/5/200928946VS.NET IDE: 60. Output 경로에 매크로 상수 사용하는 방법 [1]
687정성태4/5/200923318.NET Framework: 126. Composite Application Guidance for WPF and Silverlight
689정성태4/5/200923173    답변글 .NET Framework: 126.1. CAG - 빌드 환경 구성파일 다운로드1
691정성태4/6/200922971    답변글 .NET Framework: 126.2. CAG - Shell 띄우기파일 다운로드1
695정성태4/10/200924720    답변글 .NET Framework: 126.3. CAG - 간단한 유형의 모듈 제작파일 다운로드1
703정성태4/18/200923547        답변글 .NET Framework: 126.6. CAG - Tabbed MDI Shell 적용파일 다운로드1
697정성태4/13/200927802    답변글 .NET Framework: 126.4. CAG - Unity 컨테이너 사용 [1]파일 다운로드1
698정성태4/15/200927089    답변글 .NET Framework: 126.5. CAG에 MVVM 패턴 적용 (1) [2]파일 다운로드1
686정성태4/4/200948766웹: 11. IE 8 - TabProcGrowth 레지스트리 키 [2]
685정성태4/3/200949519개발 환경 구성: 38. Hyper-V 사용 후기 [5]
684정성태4/2/200924010오류 유형: 74. IE 8 설치 이후, VS.NET 위저드 화면 동작 오류
683정성태3/28/200930705디버깅 기술: 26. 보호 모드로 응용 프로그램 디버깅하는 방법 - 두 번째 이야기 [3]
682정성태3/27/200927876디버깅 기술: 25. 보호 모드로 응용 프로그램 디버깅하는 방법 [2]
681정성태3/23/200925067오류 유형: 73. SQL Server 2008 Express 설치 오류
680정성태3/21/200924955.NET Framework: 125. WPF - RadioButton에 대한 데이터바인딩(2) [1]파일 다운로드1
679정성태3/15/200920047오류 유형: 72. IE 8 멈춤 현상 - 두 번째 이야기
678정성태3/15/200925154개발 환경 구성: 37. Hyper-V에서 Vista의 Virtual Machine Bus 장치 인식 문제
677정성태3/15/200925663개발 환경 구성: 36. MSI P45 Neo3-FR V2 - RAID 1 구성
997정성태2/26/201120957    답변글 개발 환경 구성: 36.1. 개발 환경 구성: 34 - 1. RAID 1 구성 이후...
... 166  167  168  169  170  171  [172]  173  174  175  176  177  178  179  180  ...