32bit 주소체계는 왜 그 이상을 사용하지 않았나요?

skycloud의 이미지

질문은 이렇습니다.
32bit컴퓨터는 한 번에 32bit밖에 표현을 못하니깐 한계가 있었잖아요
예를 들어 램을 4gb밖에 못 사용한다던가. 그러면 왜 더블 연산을 통해서 사용하지 않았나요?
물론 속도는 떨어지겠지만 사실 32bit연산에서도 64bit연산을 위한 레지스터가 있는 걸로 아는데
그렇게 하면 메모리 접근도 더 가능하지 않나요?

예전 인텔 8080은 8bit 프로세서이지만 메모리 접근은 2^16개의 접근이 가능하다고 했는데
이것처럼 말이죠

xtiinhs의 이미지

이렀습니다(X) -> 이렇습니다(O)

8080의 instruction 길이는 1, 2, 3바이트가 올 수 있었고 주소 버스가 16비트였기 때문에 64 KiB까지 주소에 바로 접근이 가능하죠(단 데이터 버스는 8비트).

Quote:
그러면 왜 더블 연산을 통해서 사용하지 않았나요?

8086은 주소 버스를 20비트로 확장하긴 했지만 16비트 프로세서였기 때문에 메모리의 다른 영역에 접근할 때 세그먼트 레지스터라는 걸 사용하게 됩니다. 도스 프로그래밍을 하다 보면 저 개념을 제대로 이해했어야 했죠. near, far pointer란 게 그래서 나왔습니다. 32비트 시대가 되면서 그게 사라졌죠. 32비트 시기에도 PAE라는 게 있어서 그걸 통해서 64GB까지 메모리 "사용"은 가능했지만 결국 주소 공간의 크기는 32비트였다는 건 변하지 않았습니다. 그리고 이걸 염두에 두지 않고 작성된 32비트 코드는 PAE를 활성화시키면 메모리 관련 오류가 발생하죠.

https://ko.wikipedia.org/wiki/X86_%EB%A9%94%EB%AA%A8%EB%A6%AC_%EB%B6%84%ED%95%A0
https://www.geeksforgeeks.org/what-are-near-far-and-huge-pointers/
https://en.wikipedia.org/wiki/Physical_Address_Extension

Quote:
사실 32bit연산에서도 64bit연산을 위한 레지스터가 있는 걸로 아는데

MMX용 레지스터 이야기하는 건가요? 레지스터라고 해서 다 같은 역할을 하는 게 아닙니다. 일반적인 정수 연산용 레지스터는 여전히 32비트였습니다.

skycloud의 이미지

그렇다면 여러가지 문서나 책에서 나오는 32bit 컴퓨터는 32bit까지의 주소만 읽는 것이 가능하다라는 것을 주소버스가 32bit였다고 해석해도 될까요?
+ pae를 사용하지 않고 주소버스를 확장하는 방법은 채택되지 않았나요?
+ 제가 말한 64bit 연산 레지스터의 의미는 32bit 데이터의 결과를 두 개의 레지스터에 나눠서 저장하는 방식을 의미했고 이것을 주소에도 사용하면 되지 않을까 였습니다.

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.