본문 바로가기

쓰기

코드 게시글에 '스마트 방식이라 윈7에서 튕길지도 모른다'는 잘못된 인식을 불어넣는 것을 발견했기에 미리 사전에 이야기합니다.


해당사항의 정확한 원인은 아직까지 발견된 사례의 하나인

기가사나 타 브랜드에서 사용하는 넥서스 엔진에서만 해당하는 사항이며


그 엔진에서는 스마트 방식만이 아닌 포인터 바꿔치기로도 또한 튕깁니다.

이것이 어째서 윈 xp 에서는 안튕기고 윈7 에서만 튕기냐 입니다만

간단히 이유가


아랄 dll 에서 할당받은 메모리를 게임 엔진인 외부에서 직접 해제하려고 들때

xp는 해제 후 해제 한 메모리의 -0x4, -0x8 지점의 값을 그대로 두지만

윈7에서는 좀 더 메모리의 참조 및 간섭이 엄격해져 2개소의 값을 초기화 해버립니다.


따라서 아랄이 게임에서 초기화 해버린 메모리를 다시 읽으려 할때나

게임 자체에서 해당 메모리의 +- 위치에서 메모리 재할당을 시도할 경우

튕기는 것으로 확인되었습니다.



즉, 위를 해결하기 위해 복구코드가 생기게 되었으며

복구코드로 게임 자체에서 메모리를 할당하거나, 해제하기 이전의 위치에서

우리가 사용하고자 하는 곳에서만 데이터를 바꿔치고 원래대로 되돌려 놓기 위하여 구현된 것입니다.




정리하면 윈7에서는 스마트 방식이 튕길수도 있다는 정보는 전혀 올바르지 못하고

포인터 바꿔치기의 형태로 동작하는건 전부 튕긴다가 맞습니다.

(애시당초 스마트 방식은 '포인터 바꿔치기'에 하위개념으로 포함되옵니다.)

또한 메모리 해제에 별 지장이 없는 지역에 후킹한다면 윈7에서도 문제는 당연히 없습니다.

결국 제대로 된 장소에 후킹을 하지 못했다는 것입니다.


이상, 잘못된 견해를 올바르게 고치고자 작성하였습니다.

분류 :
Talk
조회 수 :
666
등록일 :
2013.07.06
20:37:24
엮인글 :
https://arallab.hided.net/107822/dfa/trackback
게시글 주소 :
https://arallab.hided.net/board_devtalk/107822

Wales

2013.07.06
20:54:51

기가의 사례가 와전된듯 싶습니다.

윈7이라고 스마트방식에서 잘 팅기는게 아니죠.


뭐...요점은 좀더 안정적인 지점을 찾으면 되는 겁니다[.....]



두통

2013.07.06
21:26:00

XP 유저로 코드를 올리다보면 유독 스마트 방식으로 코드를 올릴경우 항시 따라붙는 댓글이 WIN7 튕깁니다

이러다보니 이게 IME 관련 유저문제인지 (이것도 유독 스마트후킹때만 발생하는 문제이고)

후킹방식의로 인한 다른 문제인지 확인할수는 없지만

경험적으로 자주 튕긴다는걸 인지하고있는 저로서는 빠른 아랄후킹을 포기하고 타 후킹툴을 쓰라는 권고적인 메세지로

위 문구를 적어 놓고있습니다.


최근에는 스마트+복구코드로 올리고있는데 이 경우에는 대다수 문제가 없더군요.


스마트도 아닌 포인터도 튕긴다는 경우는 GXP및 미노리사는

포인터로 했을시 문제없지만 스마트로 했을시 문제가 있었던 경우입니다.


시글러스도 작년에는 WIN7에서도 됐다는 글이 있었지만 최근에 올린건 대부분 튕긴다는 글이더군요.


넥서스도 튕긴다고했지만. 길이 원문에 맞춤 + 스마트로 가능하다는 게시글도있습니다.



된다는 사람이 반절 안된다는 사람이 반절

이러하다보니 스마트+WIN7 = 호환안좋다 라는 인식이 생겨버렸나보군요.


기가사

마테리얼 브레이브 이그니션(1.03v추가,win7코드추가)




GXP 엔진 계열

えれくと! 初回限定 PREMIUM EDITION (수정)


미노리사

[수정]여름 하늘의 페르세우스 , 夏空のペルセウス


호크아이 이름및 선택지

츠치도씨의 순애로드 , 辻堂さんの純愛ロード


AIW6

마려 환자는 가텐계 (麻呂の患者はガテン系)


시글러스엔진



계속 WIN7튕긴다는 댓글을 보다보니 노이로제 걸린듯....


TwoComet

2013.07.07
03:37:48

실제 위 4작품은 윈7 에서 86/64 bit 2가지

제가 사용하는 컴퓨터들에 확인결과시 전부 이상없이 되었습니다.


댓글들은 아마 윈7이 나오지 않았다고 하여도

xp 유저들이 튕긴다는 댓글이 난무했을 것입니다.
(과거 코드글을 보시면 같은 느낌의 글들이 많습니다)

이것은 없어지지 않는 계층들입니다.

굴러가는시간

2013.07.06
22:00:43

이건 윈7, xp의 문제가 아닌듯 싶네요..

그냥 타인의 컴퓨터에 최적화된 코드를 받아 써서 생기는 문제인 듯 합니다.

시간이 지나면 다들 튕길 수도 있다는걸 받아들이겠죠.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 Talk [필독] 테스트필터 사용시 주의사항 라파에 2008-08-03 155445
409 Archive [실행파일, 플러그인] AralTrans, ATCTNR, ATCode 130804 (수정) [4] file TwoComet 2013-08-04 880
408 Archive [플러그인] ATCode, ezTransXP, TransCAT 130728 (수정) file TwoComet 2013-07-28 1297
407 Archive [실행파일] AralTrans 130710 (7/28일자 부터 포함) file TwoComet 2013-07-10 533
406 Archive [플러그인] ATCode 130707 (파기) [44] TwoComet 2013-07-07 1915
» Talk 스마트 방식과 윈7의 호환에 관한 잘못된 견해 [4] TwoComet 2013-07-06 666
404 Archive [플러그인] ATCode 130703 [20] file TwoComet 2013-07-03 783
403 Archive [플러그인] ATCode 130623 (수정) [17] file TwoComet 2013-06-22 891
402 Archive ATCTNR, ATCode, Cached, DebuggingATCode, KiriKiri, NonCached 130616 [13] file whoami 2013-06-16 871
401 Archive [실행파일] AralTrans 130601 file TwoComet 2013-06-02 577
400 Talk 정말 오래간만입니다. [5] Hide_D 2013-05-08 694
399 Archive [플러그인] ATCode 130415 file TwoComet 2013-04-15 2898
398 Talk 어플로케일이 후킹하는 함수리스트... [2] TwoComet 2013-03-22 868
397 Archive [플러그인] TransCAT 130316 (번역플러그인) [2] file TwoComet 2013-03-16 2840
396 Talk 아랄트랜스 번역플러그인에 이 프로그램들을 추가해주시면 안될까요? [5] 암흑마제 2013-03-14 1552
395 Talk 변경된 소스 좀 올려주세요. [1] whoami 2013-03-06 715
394 Archive [실행파일, 플러그인] AralTrans, AralUpdater, ATCTNR 130225 file TwoComet 2013-02-25 1042
393 Archive [플러그인] ATCode 130219 [1] file EroGame 2013-02-19 987
392 Archive [플러그인] ATCode 130203 file EroGame 2013-02-03 820
391 Archive [플러그인] ATCTNR,ATCode 130202 file EroGame 2013-02-02 715
390 Archive [실행파일, 플러그인] AralTrans, AralUpdater, ATCTNR, ATCode 2013/01/31 [2] file EroGame 2013-01-30 1445