코드 게시글에 '스마트 방식이라 윈7에서 튕길지도 모른다'는 잘못된 인식을 불어넣는 것을 발견했기에 미리 사전에 이야기합니다.
해당사항의 정확한 원인은 아직까지 발견된 사례의 하나인
기가사나 타 브랜드에서 사용하는 넥서스 엔진에서만 해당하는 사항이며
그 엔진에서는 스마트 방식만이 아닌 포인터 바꿔치기로도 또한 튕깁니다.
이것이 어째서 윈 xp 에서는 안튕기고 윈7 에서만 튕기냐 입니다만
간단히 이유가
아랄 dll 에서 할당받은 메모리를 게임 엔진인 외부에서 직접 해제하려고 들때
xp는 해제 후 해제 한 메모리의 -0x4, -0x8 지점의 값을 그대로 두지만
윈7에서는 좀 더 메모리의 참조 및 간섭이 엄격해져 2개소의 값을 초기화 해버립니다.
따라서 아랄이 게임에서 초기화 해버린 메모리를 다시 읽으려 할때나
게임 자체에서 해당 메모리의 +- 위치에서 메모리 재할당을 시도할 경우
튕기는 것으로 확인되었습니다.
즉, 위를 해결하기 위해 복구코드가 생기게 되었으며
복구코드로 게임 자체에서 메모리를 할당하거나, 해제하기 이전의 위치에서
우리가 사용하고자 하는 곳에서만 데이터를 바꿔치고 원래대로 되돌려 놓기 위하여 구현된 것입니다.
정리하면 윈7에서는 스마트 방식이 튕길수도 있다는 정보는 전혀 올바르지 못하고
포인터 바꿔치기의 형태로 동작하는건 전부 튕긴다가 맞습니다.
(애시당초 스마트 방식은 '포인터 바꿔치기'에 하위개념으로 포함되옵니다.)
또한 메모리 해제에 별 지장이 없는 지역에 후킹한다면 윈7에서도 문제는 당연히 없습니다.
결국 제대로 된 장소에 후킹을 하지 못했다는 것입니다.
이상, 잘못된 견해를 올바르게 고치고자 작성하였습니다.
두통
- 2013.07.06
- 21:26:00
XP 유저로 코드를 올리다보면 유독 스마트 방식으로 코드를 올릴경우 항시 따라붙는 댓글이 WIN7 튕깁니다
이러다보니 이게 IME 관련 유저문제인지 (이것도 유독 스마트후킹때만 발생하는 문제이고)
후킹방식의로 인한 다른 문제인지 확인할수는 없지만
경험적으로 자주 튕긴다는걸 인지하고있는 저로서는 빠른 아랄후킹을 포기하고 타 후킹툴을 쓰라는 권고적인 메세지로
위 문구를 적어 놓고있습니다.
최근에는 스마트+복구코드로 올리고있는데 이 경우에는 대다수 문제가 없더군요.
스마트도 아닌 포인터도 튕긴다는 경우는 GXP및 미노리사는
포인터로 했을시 문제없지만 스마트로 했을시 문제가 있었던 경우입니다.
시글러스도 작년에는 WIN7에서도 됐다는 글이 있었지만 최근에 올린건 대부분 튕긴다는 글이더군요.
넥서스도 튕긴다고했지만. 길이 원문에 맞춤 + 스마트로 가능하다는 게시글도있습니다.
된다는 사람이 반절 안된다는 사람이 반절
이러하다보니 스마트+WIN7 = 호환안좋다 라는 인식이 생겨버렸나보군요.
기가사
마테리얼 브레이브 이그니션(1.03v추가,win7코드추가)
GXP 엔진 계열
えれくと! 初回限定 PREMIUM EDITION (수정)
미노리사
호크아이 이름및 선택지
AIW6
시글러스엔진
계속 WIN7튕긴다는 댓글을 보다보니 노이로제 걸린듯....
기가의 사례가 와전된듯 싶습니다.
윈7이라고 스마트방식에서 잘 팅기는게 아니죠.
뭐...요점은 좀더 안정적인 지점을 찾으면 되는 겁니다[.....]