✨Intel 80386

Intel 80386

nhỏ|Intel A80386DX-20 CPU die image Intel 80386 (ban đầu là 80386 và sau này còn gọi là i386) là bộ vi xử lý 32-bit được giới thiệu năm 1985. Nó có 275 000 transistor và được sử dụng trong nhiều máy tính cá nhân cao cấp và máy trạm vào thời đó. 80386 là một mở rộng 32 bit của kiến trúc 80286. Tập lệnh, mô hình lập trình và các mã của nó vẫn là yêu cầu đối với các vi xử lý x86 32-bit, và chúng được gọi là kiến trúc i386, hay còn gọi là IA-32.

i386 có thể thực thi chính xác các chương trình cho các vi xử lý 16-bit trước đó là 8086 và 80286. Qua thời gian, các phiên bản cải tiến trên cùng một kiến trúc i386 nhanh gấp hàng trăm lần phiên bản gốc (và nhanh gấp hàng nghìn lần so với 8086). Một phiên bản 20 MHz có tốc độ thực thi lên tới 4-5 triệu dòng lệnh mỗi giây. Phiên bản nhanh nhất của Intel có xung 33 MHz và thực thi được khoảng 11,4 triệu dòng lệnh mỗi giây.

Quá trình phát triển i386 bắt đầu vào năm 1982 với tên gọi nội bộ là P3. Bản vẽ cuối của nó được hoàn thiện vào tháng 7 năm 1985. Quá trình sản xuất ở quy mô lớn bắt đầu vào tháng 6, 1986. Các bo mạch chủ và hệ thống đầu tiên sử dụng 80386 không ổn định và có giá thành cao. Máy tính cá nhân đầu tiên sử dụng một vi xử lí 80386 là Compaq Deskpro 386. Nó cũng đi vào lịch sử như là máy tính cá nhân tương thích IBM đầu tiên thiết lập một tiêu chuẩn không phải do IBM.

Vào tháng 5 2006, Intel thông bố rằng sẽ dừng việc sản xuất các chip i386 vào cuối tháng 9 năm 2007. Mặc dù từ lâu nó đã không còn xuất hiện trong các máy tính cá nhân, Intel và một số công ty vẫn sản xuất các chip 386 dành cho hệ thống nhúng. Các hệ thống như vậy xuất hiện nhiều trong các công nghệ hàng không và các thiết bị âm nhạc. Linux ngưng hỗ trợ các vi xử lý 386 vào ngày 11 tháng 12 năm 2012, trong phiên bản 3.8.

Kiến trúc

trái|nhỏ|300x300px|Sơ đồ khối của thiết kế i386

|} Bộ xử lý 80386 là một bước tiến đáng kể của dòng vi xử lý x86. Các vi xử lý trước đó chỉ có các thanh ghi 16-bit và sử dụng cơ chế bảo vệ và quản lý bộ nhớ thông qua đoạn (segment). 80386 được thiết kế với đường ống lệnh (pipeline) sáu giai đoạn, mở rộng kiến trúc 16 bit lên thành 32 bit và tích hợp một bộ quản lý bộ nhớ sử dụng trang (paging). Nhờ đó việc thiết kế các hệ điều hành với bộ nhớ ảo trở cho kiến trúc nên dễ dàng hơn nhiều. Ngoài ra 80386 còn hỗ trợ các thanh ghi gỡ lỗi.

80386 có ba chế độ vận hành: chế độ thực (real mode), chế độ bảo vệ (protected mode) và chế độ 8086 ảo (virtual 8086 mode). Chế độ bảo vệ xuất hiện trong 80286, nay được mở rộng để hỗ trợ lên tới 4 GB. Chế độ ảo 8086 là chế độ mới, cho phép chạy đồng thời nhiều chương trình viết cho chế độ thực trong một môi trường bảo vệ.

Khả năng thiết lập một mô hình bộ nhớ phẳng trong chế độ bảo vệ của 386, mặc dù nó sử dụng mô hình phân đoạn trong mọi chế độ, được xem là thay đổi quan trọng nhất của dòng vi xử lý x86, cho đến khi AMD giới thiệu kiến trúc x86-64 vào năm 2003.

Một số lệnh mới được thêm vào 386: BSF, BSR, BT, BTS, BTR, BTC, CDQ, CWDE, LFS, LGS, LSS, MOVSX, MOVZX, SETcc, SHLD, SHRD.

Hai thanh ghi mới được thêm vào dành cho mục đính sự dụng thông thường (FS và GS). Các thanh ghi gỡ lỗi DR0-DR7 được thêm vào cho các điểm dừng (breakpoint) sử dụng phần cứng.

Kiến trúc sư trưởng của dự án 80386 là John H.Crawford, người có trách nghiệm mở rộng kiến trúc và tập lệnh của 80286 lên 32-bit, và phát triển vi mã cho 80386.

Các bộ xử lý i486 và Pentium P5 là các thiết kế kế thừa i386.

Các kiểu dữ liệu

Các các kiểu dữ liệu sau đây được hỗ trợ trực tiếp và xuất hiện trong ít nhất một phiên bản của mã i386. Chúng bao gồm:

-->

  • Bit (giá trị boolean), bit field (nhóm lên tới 32 bit) và bit string (có độ dài lên tới 4 GBit).
  • 8-bit integer (byte), bao gồm dạng có dấu (khoảng −128..127) hay không dấu (khoảng 0..255).
  • 16-bit integer, bao gồm dạng có dấu (khoảng −32,768..32,767) hay không dấu (khoảng 0..65,535).
  • 32-bit integer, bao gồm dạng có dấu (khoảng −231..231−1) hay không dấu (khoảng 0..232−1).
  • Offset, một độ lệch 16 bit hoặc 32-bit trỏ tới một ô nhớ (sử dụng bất kỳ chế độ bộ nhớ nào).
  • Pointer, bao gồm phần gốc 16-bit và độ lệch 16 bit hoặc 32 bit.
  • Character (mã ký tự 8 bit).
  • String, một xâu các word 8 bit, 16 bit hoặc 32 bit (có độ dài lên tới 4 GBit).
  • BCD, các chữ số thập phân (0..9) mô tả bởi các byte chưa đóng gói.
  • Packed BCD, hai chữ số BCD trong một byte (khoảng 0..99)

Chương trình ví dụ

Đoạn mã dưới đây sử dụng các lệnh hợp ngữ i386 cho một chuơng trình con có tên là _strtolower. Chương trình này sao chép một xâu ký tự ASCIIZ được kết thúc bởi một ký tự null, sang một địa chỉ khác và biến cả các ký tự chữ hoa thành chữ thường. Quá trình sao chép diễn ra theo từng byte (mỗi ký tự).

Ví dụ trên sử dụng con trỏ gốc, hay thanh ghi EBP, để tạo một khung lời gọi (call frame), một vùng trên stack chứa tất cả các tham số và biến cục bộ của hàm. Kiểu quy tắc lời gọi này hỗ trợ các mã đệ quy và reentrant, và được sử dụng trong các ngôn ngữ tương tự Algol kể từ thập niên 1950. Nó ngầm định một mô hình bộ nhớ phẳng, tức là các đoạn DS và ES cùng trỏ tới một vị trí trong bộ nhớ.

Tầm quan trọng kinh doanh

Máy tính cá nhân đầu tiên sử dụng i386 là Compaq Deskpro 386. Bằng cách mở rộng kiến trúc 16/24 bit của IBM PC/AT lên thành 32 bit, Compaq trở thành công ty đầu tiên thiết kế và sản xuất một bước cải tiến lớn trong nền tảng PC. IBM được liên hệ để trở thành khách hàng của 80386, tuy nhiên họ vẫn còn nắm giữ quyền sản xuất 80286. IBM chọn cách tiếp tục đầu tư cho 80286 thêm một vài năm nữa. Sự thành công của Compaq Deskpro 386 đóng vai trò quan trọng trong việc hợp pháp hóa nền công nghiệp PC và làm giảm tầm ảnh hưởng của IBM trong đó.

Trước 386, các khó khăn trong việc sản xuất chip và do nguồn cung không được đảm bảo dẫn tới việc yêu cầu các bộ phận bán dẫn phải được sản xuất bởi nhiều hãng khác nhau (multi-sourced). Tuy nhiên, trong suốt một thời gian dài (4,7 năm) chỉ có duy nhất Intel sản xuất 80386, do CEO của Intel lúc đó là Andy Groove quyết định không cấp phép vi xử lý cho bất kỳ hãng sản xuất nào khác. Quyết định này mang tới thành công lớn cho Intel trên thị trường. Việc độc quyền sản xuất 386 cũng giúp cho Intel có nhiều sự kiểm soát lên quá trình phát triển cũng như lợi nhuận trong những năm sau này.

AMD giới thiệu dòng vi xử lý tương thích của mình, Am386, vào tháng 3 năm 1991, sau khi vượt qua nhiều rào cản pháp lý. Nó chấm dứt giai đoạn độc quyền gần 5 năm của Intel đối với kiến trúc i386. Trong cùng năm IBM cũng được cấp phép để sản xuất các chip 386 dành riêng cho các máy tính và bo mạch chủ của hãng.

Sự lỗi thời

Windows 95 là phiên bản Windows 9x duy nhất chính thức hỗ trợ i386. Nó yêu cầu một chip 386DX, và khuyến nghị các vi xử lý i486 và tốt hơn. Windows 98 yêu cầu 486DX hoặc cao hơn. Trong các hệ điều hành Windows NT, phiên bản cuối cùng hỗ trợ i386 là 3.51.

Debian gỡ bỏ hộ trợ 386 trong phiên bản 3.1 (Sarge) vào năm 2005. Các nhà phát triển Linux kernel dừng hỗ trợ 386 kể từ tháng 12 năm 2011, với lý do các cản trở liên quan tới SMP, trong phiên bản 3.8.

👁️ 3 | 🔗 | 💖 | ✨ | 🌍 | ⌚
nhỏ|Intel A80386DX-20 CPU die image **Intel 80386** (ban đầu là **80386** và sau này còn gọi là **i386**) là bộ vi xử lý 32-bit được giới thiệu năm 1985. Nó có 275 000 transistor và
**CPU Intel** là các loại CPU do hãng Intel thiết kế và sản xuất. ## Lịch sử CPU Intel ### Bộ xử lý 4-bit 4004 là bộ vi xử lý đầu tiên được Intel giới
**Intel 8088** là một biến thể của vi xử lý 8086, với bus dữ liệu ngoài 8 bit thay vì 16 bit. Các thanh ghi 16 bit được giữ nguyên và giới hạn không gian
Thuật ngữ **x86** dùng để chỉ tới kiến trúc tập lệnh của dòng vi xử lý 8086 của Intel. 8086 được Intel đưa ra năm 1978. Intel xem dòng phát triển 8086 là IA-32. Kiến
**Pat Gelsinger**, hay còn được biết đến với tên đầy đủ là **Patrick Paul Gelsinger** (phát âm: ; sinh ngày 5 tháng Ba năm 1961) là một kỹ sư, doanh nhân kiêm quản lý công
**OS/2** là một loạt các hệ điều hành máy tính, ban đầu được tạo ra bởi Microsoft và IBM dưới sự lãnh đạo của nhà thiết kế phần mềm IBM Ed Iacobucci. Do tranh cãi
Chương trình máy tính tưởng rằng nó có một dải dài các địa chỉ liên tục trong bộ nhớ; nhưng trong thực tế một số phần đang được sử dụng nằm rải rác trong [[RAM,
Đây là danh sách các hệ điều hành. Hệ điều hành máy tính có thể được phân loại theo công nghệ, quyền sở hữu, giấy phép, trạng thái hoạt động, cách dùng, và nhiều đặc
**Pascal** là một ngôn ngữ lập trình cho máy tính thuộc dạng mệnh lệnh và thủ tục, được Niklaus Wirth phát triển vào năm 1970. Pascal là ngôn ngữ lập trình đặc biệt thích hợp
phải|AMD Am386DX-40 CPU Bộ xử lý trung tâm **Am386** được AMD ra mắt vào năm 1991. Một CPU nhân bản tương thích-100% theo thiết kế của Intel 80386, được bán ra hàng triệu bản và
nhỏ|300x300px|Trong máy tính sử dụng [[bộ nhớ ảo, việc truy cập vị trí tương ứng với một địa chỉ bộ nhớ có thể bao gồm nhiều tầng.]] Trong máy tính, **địa chỉ bộ nhớ** là
**Hệ điều hành** (tiếng Anh: Operating system, viết tắt: OS) là phần mềm hệ thống quản lý tài nguyên phần cứng máy tính, phần mềm và cung cấp các dịch vụ chung cho các chương
**Microsoft Windows** (**Windows**) là một họ hệ điều hành dựa trên giao diện người dùng đồ hoạ được phát triển và được phân phối bởi Microsoft. Nó bao gồm một vài các dòng hệ điều
**BlackBerry** là một dòng thiết bị gửi nhận email di động và điện thoại thông minh do công ty Research In Motion (RIM) của Canada phát triển và thiết kế trong hơn một thập kỷ.
Tên **EMM386** được sử dụng cho việc quản lý bộ nhớ mở rộng cho cả Microsoft MS-DOS và Digital Research DR-DOS, để tạo bộ nhớ mở rộng sử dụng bộ nhớ mở rộng trên CPU
**Windows NT 3.51** là phiên bản phát hành thứ ba trong dòng hệ điều hành Windows NT của Microsoft. Nó được phát hành vào ngày 30 tháng 5 năm 1995, chín tháng sau Windows NT
**Lịch sử của Linux** bắt đầu vào năm 1991 với sự bắt đầu của một dự án cá nhân của sinh viên Phần Lan Linus Torvalds để tạo ra một hạt nhân hệ điều hành
**Chế độ thực**, cũng được gọi là **chế độ địa chỉ thực**, là một chế độ hoạt động của tất cả các CPU tương thích x86. Chế độ thực được đặc trưng bởi không gian
**IA-32** (viết tắt của "**Intel Architecture, 32 bit** ", đôi khi còn được gọi là **i386** ) là phiên bản 32 bit của kiến trúc tập lệnh x86, được thiết kế bởi Intel và được
**Windows 2.1** là một bản phát hành lớn của Microsoft Windows. Nó được phát hành tới các nhà sản xuất vào ngày 27 tháng 5 năm 1988, thay thế phiên bản Windows 2.0. Windows 2.1
Trong máy tính, **chế độ bảo vệ**, còn được gọi là **chế độ địa chỉ ảo được bảo vệ**, là một chế độ hoạt động của các đơn vị xử lý trung tâm tương thích
**Đơn vị quản lý bộ nhớ (MMU)**, hay còn gọi là **trang quản lý bộ nhớ (PMMU)** là một thiết bị phần cứng chứa tất cả những tham chiếu của bộ nhớ đã đi qua
**Windows 3.0** là bản phát hành lớn thứ ba của Microsoft Windows, được ra mắt vào năm 1990. Phiên bản này giới thiệu một giao diện người dùng đồ họa (GUI) mới, trong đó các