x86-64 운영체제를 만들자 [-] x86 아키텍쳐의 변화: 16, 32 그리고 64

cppig1995의 이미지

x86 아키텍쳐는 두 번 변화했습니다: 16->32 (1985, Intel 80386) 그리고 32->64 (2003, AMD Athlon64) 이렇게 말입니다.
QnA 형식으로 강좌를 써 보겠습니다. * 모든 "x86-64 운영체제를 만들자" 강좌는 CC 3.0 by-nc-sa 저작권입니다.
http://creativecommons.org/licenses/by-nc-sa/3.0/deed.ko

원래 엄청 길게 쓰고, 위키백과 x86 관련 글도 번역하고 했었는데 '포럼 주제 만들기'의 입력 형식 밑에
"포맷팅 옵션에 대한 추가 정보"를 누르는 순간 모든 내용이 날아갔습니다. 드루팔을 원망하겠습니다.

단순 궁금증

왜 이름이 x86일까?
8080 프로세서가 있었습니다. 동작을 위해 +5V, -5V, +12V 입력이 필요했습니다.
그 다음 인텔은 8085 프로세서를 내놓았습니다. 이제 +5V만 있으면 됩니다.
뭔가 감이 오시지 않습니까? +5V라서 8085입니다.
그 다음 인텔은 8085 8비트 프로세서를 16비트로 확장했습니다. 이름하여 8086.
그리고 그 '8086'이라는 이름 때문에 x86이라는 아키텍쳐명이 나왔습니다.
그러니까, 20년 동안 PC시장을 주도한 아키텍쳐 이름의 시작은 전압 숫자입니다. 허무하죠?

x86 아키텍쳐의 확장들

  • 32비트화: 인텔 80386. 일명 "x86-32", "IA-32", "i386" 등의 이름으로 불려집니다.
  • MMX: 인텔 펜티엄 MMX(1997). 단일 명령 다중 데이터(Single Instruction Multiple Data) 방식 인스트럭션과 MMX 레지스터 8개.
  • 3DNow!: AMD(1997). 역시 SIMD 방식이며, MMX의 확장.
  • SSE 시리즈: SSE, SSE2, SSE3, SSE4(예정). 128비트 레지스터 8개(SSE)/16개(AMD64) 제공.
  • 가상화: x86 아키텍쳐는 일반적으로 Popek/Goldberg 조건을 만족하지 않아서 가상화가 힘들었다. 그러나...
  • 64비트 롱 모드: AMD Athlon64(2003). 엄청나게 중요합니다. 이 강좌의 핵심이죠.
  • 기타: 뭐 제가 모르는 것도 많이 있겠죠?

모드, 모드, 모드?!
다음은 레거시 모드(legacy mode)의 목록입니다:

  • 실제 주소 모드(Real address mode, '리얼 모드') (16비트)
  • 일명 'Unreal mode' (비실제 모드) 일종의 프로세서 버그. 90년대 초반 일부 도스 게임에 사용.
  • 가상 8086 모드(Virtual 8086 mode, 'VM86') 보호 모드의 몇 가지 제한 사항이 완화된 모드.
  • 보호 모드 (32비트)
다음은 롱 모드(long mode)의 목록입니다:
  • 64비트 모드 64-bit mode: 새로운 운영체제 및 어플리케이션 재빌드 필요.
  • 호환성 모드 Compatibility mode: 새로운 64비트 운영체제만 있으면 됨.

본론: 32비트 보호 모드와 64비트 롱 모드의 차이

AMD64 Architecture Programmer’s Manual Volume 1: Application Programming(24592.pdf)의 3.1.2 부분을 보시면,

레지스터 관련

  • 새로운 범용 레지스터 8개가 추가되었습니다 (R8-R15).
  • 모든 16 GPR들이 64비트로 확장되었습니다 (RAX, RBX, RCX, RDX, RBP, RSI, RDI, RSP, R8-R15).
  • 모든 GPR에 대한 고유 바이트 레지스터 어드레싱.
  • 새로운 SSE 레지스터 8개가 추가되었습니다(XMM8-XMM15).
  • 64비트 플래그 레지스터 RFLAGS (그러나 하위 32비트는 EFLAGS와 같고, 상위 32비트는 0).
  • 64비트 모드에서는, 하드웨어에 의해 DS, ES, SS가 무시됩니다.
  • 확장 레지스터를 위한 새로운 인스트럭션 접두사(REX).
레지스터 이름
  • 16개의 8비트 하위-바이트 레지스터: AL, BL, CL, DL, SIL, DIL, BPL, SPL, R8B-R15B
  • 4개의 8비트 상위-바이트 레지스터: AH, BH, CH, DH (REX 접두사 미사용시만 접근가능)
  • 16개의 16비트 레지스터: AX, BX, CX, DX, DI, SI, BP, SP, R8W-R15W
  • 16개의 32비트 레지스터: EAX, EBX, ECX, EDX, EDI, ESI, EBP, ESP, R8D-R15D
  • 16개의 64비트 레지스터: RAX, RBX, RCX, RDX, RDI, RSI, RBP, RSP, R8-R15
롱 모드의 특징
  • 레지스터 관련
  • 새로운 범용 레지스터 8개가 추가되었습니다 (R8-R15).
  • 모든 16 GPR들이 64비트로 확장되었습니다 (RAX, RBX, RCX, RDX, RBP, RSI, RDI, RSP, R8-R15).
  • 모든 GPR에 대한 고유 바이트 레지스터 어드레싱.
  • 새로운 SSE 레지스터 8개가 추가되었습니다(XMM8-XMM15).
  • 64비트 플래그 레지스터 RFLAGS (그러나 하위 32비트는 EFLAGS와 같고, 상위 32비트는 0).
  • 64비트 모드에서는, 하드웨어에 의해 DS, ES, SS가 무시됩니다.
  • 확장 레지스터를 위한 새로운 인스트럭션 접두사(REX).

이 정도가 나와 있습니다.

지금 열심히 롱 모드 진입 코드 테스트하고 있습니다. 완료되면 다시 III부 쓰겠습니다.
In simplexitate est opportunitas. --cppig1995

Forums: 

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.