- 다양한 주제에 대해 자유롭게 글을 작성하는 게시판입니다.
Date 19/07/02 00:15:13
Name   호타루
Subject   드디어 헥스코드가 말을 하기 시작하다
탐라에 쓰려고 했는데 이야기가 좀 길어져서 여기에 씁니다.

암호학에서 흔히 말하는 개념으로 크립(crib)이라는 게 있습니다. 일종의 힌트죠. 독일군의 에니그마를 풀 때 블레츨리 파크 팀이었나, 거기에서 날씨를 의미하는 독일어 wetter가 이것일 것이다 하고 추정해서 암호체계를 파악한다던가, 혹은 AF가 어디냐 할 때 미드웨이에 물이 부족하다는 신호를 슬쩍 흘려서 AF가 미드웨이임을 확정지은 미국 암호팀의 기술이라던가, 이런 게 다 크립입니다.

일전에 제가 4차로봇대전 에딧을 위해 어셈블리어까지 파고들기 시작했다고 한 적이 있는데요, 사실 구조가 워낙 복잡하고 트래킹하기가 까다로워서 일단 최대한 크립을 이용하는 쪽으로 선회했습니다. (어셈블리어를 공부하기 위한 시도가 헛수고는 아니었던 게, 덕분에 롬 파일의 메모리 구조는 모조리 다 외워버렸습니다.)

사실, 기존에 나온 에디터가 있긴 합니다. 중국인이 만든 것으로 보이는 SFC super robot wars 4 editor를 이용하면 인물 / 로봇 / 무기정보를 손쉽게 에디트할 수 있죠. 물론, 저는 이 정도로는 부족했고 맵의 순서나, 적의 배치나, 레벨링 조정 등등 갖가지 많은 것들을 필요로 했습니다만... 이것들, 특히 로봇 코드는 정말 큰 도움이 되는 크립이었습니다.

이 크립의 효과는 실로 어마어마했어요. 이걸 바탕으로 로봇 이름의 주소를 역추적해서, 바이트에 대응하는 글자(ex. 제4차 슈퍼로봇대전 한글판에서 헥스코드 78은 반각 글자로 쓰여진 '배'에 해당하고, F183은 전각 글자로 쓰여진 '안'에 해당합니다.)를 모조리 다 풀어버릴 수 있었죠. 그리고 그걸 바탕으로 어디서부터 어디까지가 대사 부분인지, 번역이 좀 이상하거나 미처 안 된 텍스트는 어떻게 조정하면 되는지를 깔끔하게 다 해독해 버렸습니다. 물론 원하는 것은 그게 아니었지만 부수적으로 얻은 것도 컸죠.

그리고 이 프로그램에서는 4바이트로 저장할 데이터가 있으면 순서를 바꾼다는 점(ex. 무기 데미지 : 데미지 2000이면 07D0 -> D007로 저장)을 이용해서, 4차로봇대전 13화의 마벨이 탑승하는 보츈을 어디를 손대야 다른 로봇으로 바꿀 수 있는지를 역추적했고(기체코드가 011F라 1F01을 추적하면 될 것이라 예측했고, 그 예상은 제대로 적중했습니다), 그 역추적한 데이터에서 뽑아낸 블록의 위치를 바탕으로 근처 코드를 분석해서 첫 전장에서의 아군 등장인물과 레벨과 탑승로봇의 정보를 추적하고, 같은 기법으로 적의 등장인물과 레벨과 탑승로봇의 정보를 추적하고...

이 모든 게 한 2주 걸린 것 같아요. 오래 걸렸죠. 그나마도 주중에는 운동 갔다와서 뻗어 있는 게 일상이라 주말에 새벽 2시 4시 찍어가며 피터지게 헥스코드와 싸워댔는데, 마침내 조금씩 저의 승리가 보입니다. 아직 플래그 세우는 부분과 플래그에 따른 분기를 흐르게 하는 것은 정말 어셈블리어의 영역이라 함부로 손대기가 까다롭지만, 지금 손대고 있는 것만 해도 충분히 대성공 수준이라고 자신합니다. 소위 말하는 밸런스 패치와 파일럿 및 로봇 교체를 원하는 대로 다 손대버릴 수 있으니까요. 한 마디로, 저는 4차로봇대전에서만큼은 반신의 영역에 도달한 셈이죠.

헥스코드의 주소를 알아내고 입맛대로 데이터를 마구 바꿔내기까지의 과정은 정말로 암호해독을 방불케 합니다. 과거 제1차 세계대전에서 조르주 팽뱅이 피를 토해 가며 풀었던 암호나, 에니그마에 대항하는 봄베 내지는 퍼플 같은... 물론 그 위대한 사람들의 공로에는 발끝에도 못 미치겠지만(적어도 제가 암호를 풀어내는 게 세상을 바꾸고 뭐 그러지는 않으니까요) 스스로 암호를 풀어내고 헥스코드가 속삭이는 것을 듣게 될 때의 그 희열은 정말 짜릿합니다. 오래 전에 1995년산 고전게임 삼국지 적벽대전(그 때는 크립으로 치트 엔진과 세이브 파일을 이용했죠)을 완벽하게 해독해냈을 때의 그 희열을 참으로 오랜만에 느껴봅니다. 덕분에 오늘 늦잠자서 10분 지각했지만 그깟 지각 따위...

덕분에 이제 좀 느긋하게 헥스코드를 바꿔 가며 당분간은 좀 널럴하게 잘 수 있겠습니다. 매일 자나깨나 코드를 분석하기 위한 아이디어를 떠올리느라 딴 생각하는 게 일이었거든요.



4
  • 집중력 ㄷㄷㄷ


목록
번호 제목 이름 날짜 조회 추천
공지 티타임 게시판 이용 규정 2 토비 15/06/19 35553 1
15999 여행갑자기 써보는 벳부 여행 후기 4 쉬군 26/02/03 226 5
15998 일상/생각아파트와 빌라에서 아이 키우기 12 + 하얀 26/02/03 466 16
15997 일상/생각소유의 종말: 구독 경제와 경험의 휘발성 2 사슴도치 26/02/02 542 15
15996 오프모임참가하면 남친여친이 생겨 버리는 2월 7일 토요일 14시 사당 또는 이수 커피 모임 65 트린 26/02/02 1217 4
15995 일상/생각팀장으로 보낸 첫달에 대한 소고 6 kaestro 26/02/01 613 6
15994 일상/생각와이프란 무엇일까? 2 큐리스 26/01/31 608 9
15993 영화영화 비평이란 무엇인가 - 랑시에르, 들뢰즈, 아도르노 3 줄리 26/01/31 404 5
15992 IT/컴퓨터[리뷰] 코드를 읽지 않는 개발 시대의 서막: Moltbot(Clawdbot) 사용기 24 nm막장 26/01/31 747 1
15991 일상/생각결혼준비부터 신혼여행까지 (3/청첩장 및 본식 전, 신혼여행) 5 danielbard 26/01/30 404 4
15990 정치중국몽, 셰셰, 코스피, 그리고 슈카 15 meson 26/01/29 1155 7
15989 IT/컴퓨터램 헤는 밤. 28 joel 26/01/29 843 27
15988 문화/예술[사진]의 생명력, ‘안정’을 넘어 ‘긴장’으로 8 사슴도치 26/01/28 443 22
15987 IT/컴퓨터문법 클리닉 만들었습니다. 7 큐리스 26/01/27 584 16
15986 게임엔드필드 간단 감상 2 당근매니아 26/01/26 572 0
15983 스포츠2026년 월드컵 우승국//대한민국 예상 순위(라운드) 맞추기 관련 글 6 Mandarin 26/01/26 366 0
15982 오프모임2월 14일 신년회+설맞이 낮술모임 (마감 + 추가모집 있나?없나?) 18 Groot 26/01/26 731 3
15981 정치이재명에게 실망(?)했습니다. 8 닭장군 26/01/25 1030 0
15980 IT/컴퓨터타롯 감성의 스피킹 연습사이트를 만들었어요 ㅎㅎ 4 큐리스 26/01/25 446 0
15979 정치민주당-조국당 합당해서 무엇을 얻을 수 있을까요? 14 Picard 26/01/23 897 0
15978 오프모임1/23 (금) 용산 또는 서울역 저녁 모임 8 kaestro 26/01/23 704 1
15977 스포츠[MLB] 코디 벨린저 5년 162.5M 양키스행 김치찌개 26/01/22 338 0
15976 정치한덕수 4천자 양형 사유 AI 시각화 11 명동의밤 26/01/21 1194 11
15974 오프모임2월 7일 토요일 14시 사당 또는 이수 커피 모임 하실 분? 21 트린 26/01/20 907 5
15973 도서/문학용사 힘멜이라면 그렇게 했을테니까 7 kaestro 26/01/19 1047 9
목록

+ : 최근 2시간내에 달린 댓글
+ : 최근 4시간내에 달린 댓글

댓글