BIOS 프로그램을 작성하는 데 어떤 프로그래밍 언어가 사용됩니까?


65

내가 이해하는 것처럼 ROM에 들어있는 BIOS 코드 / 비트 스트림은 일반적이어야합니다 (여러 CPU 유형 또는 ISA와 함께 작동). 또한 웹에서 코드를 덤프하고 "해체"할 수 있다고 언급했습니다.

그렇다면 어떤 언어, 명령어 세트 또는 머신 코드로 작성 되었습니까? 작업을 수행하는 데 어떤 종류의 프로세서가 필요하지 않습니까? 그렇다면 외부 CPU를 사용할 것이라고 생각합니다. 그렇다면 채용 된 특정 명령 세트를 어떻게 알 수 있습니까?

내부 프로세서가 있습니까?



39
교차 게시 는 충분히 나쁘지만 두 버전 의 핫 네트워크 질문 으로 끝날 때 창백한 것 이상입니다.
Mason Wheeler

8
"ROM에 들어있는 BIOS 코드 / 비트 스트림은 일반적이어야합니다 (여러 CPU 유형 또는 ISA와 함께 작동)." - 여러 ISA에서 작동하는 BIOS에 대해 들어 본 적이 없습니다 . 예가 있습니까?
chx

6
As I understand, the BIOS code/bitstream that is held in the ROM should be generic (work alongside with multiple CPU types or ISAs). 나는 "아니오, 단지 반대"라고 말하고 싶습니다
edc65

11
이것은 "컴퓨터는 어떻게 작동합니까?"와 같은 일반적인 질문의 복제물이 아닙니다. 속임수로 닫지 마십시오.
Andres F.

답변:


103

BIOS는 어셈블리 언어로만 작성되었지만, 코드의 대부분을 일부 고급 언어로 작성하고 가능한 한 적은 부분, 바람직하게는 부트 스트 래퍼, (시작 / 재설정 후 CPU가 이동하는 처음 몇백 개의 명령) 및 모든 기본 루틴은 기본 아키텍처의 특정 문제를 처리합니다.

BIOS는 이미 90 년대 초반에 주로 C로 작성되었습니다. (90 년대 초에 90 % C, 10 % 어셈블리로 BIOS를 작성했습니다.)

이 방향에서 크게 도움이 된 것은 다음과 같습니다.

  • 특정 아키텍처를 대상으로하고 해당 아키텍처의 특성을 처리하기위한 기능 (예 : x86 아키텍처의 I / O 포트에서 바이트를 읽거나 쓰는 기능)을 포함하는 C 라이브러리. Microsoft C는 항상 이러한 종류의 라이브러리 라이브러리 기능을 제공했습니다.

  • 특정 CPU 아키텍처를 대상으로 할뿐만 아니라 특수 CPU 기능을 사용하는 코드를 작성하기 위해 사용할 수있는 C 언어 확장을 제공하는 C 컴파일러. 예를 들어, x86 아키텍처는 인터럽트 처리기 (interrupt handler)라고하는 루틴을 호출하는 인터럽트 (interrupt)라고하는 것을 지원하며, 특별한 진입 / 종료 명령 시퀀스가 ​​필요합니다. 초창기부터 Microsoft C는 함수를 인터럽트 핸들러로 표시하는 데 사용할 수있는 특수 키워드를 지원하므로 CPU 인터럽트에 의해 직접 호출 될 수 있으므로 어셈블리를 작성할 필요가 없습니다.

요즘에는 대부분의 BIOS가 더 높은 수준의 언어가 아닌 경우 C ++로 작성되었다고 가정합니다.

BIOS를 구성하는 대부분의 코드는 기본 하드웨어에 따라 다르므로 실제로 이식 할 필요는 없습니다. 항상 동일한 유형의 CPU에서 실행되도록 보장됩니다. CPU는 발전 할 수 있지만 이전 버전과의 호환성을 유지하는 한 BIOS를 수정하지 않고 실행할 수 있습니다. 또한 C로 작성된 BIOS 부분을 항상 다시 컴파일하여 필요한 경우 새로운 CPU에서 기본적으로 실행되도록 할 수 있습니다.

우리가 어셈블리보다 높은 수준의 언어로 BIOS를 작성하는 이유는 실제로 이식 가능해야하기 때문이 아니라 이런 방식으로 작성하는 것이 더 쉽기 때문입니다.


7
예. 때로는 특정 CPU 아키텍처뿐만 아니라 특정 CPU 공급 업체에 마더 보드가 바인딩되어있을 수도 있습니다. 요즘에는 Intel x86 CPU 와만 호환되는 x86 마더 보드 또는 AMD x86 CPU 와만 호환되는 x86 마더 보드를 구입할 수 있습니다. 두 가지 경우 모두 CPU가 x86 명령어 세트를 이해하고 대부분의 주변 장치는 동일하지만 일부 주변 장치에는 차이가있어서 BIOS가 고려해야하기 때문에 이러한 마더 보드의 BIOS는 대부분 동일합니다.
Mike Nakis

4
@Reflection은 마더 보드가 실제로 어떻게 보이는지 자세히 살펴 봅니다. CPU 소켓에는 특정 핀 배열이 있으며 이는 수용하는 CPU 제품군에 따라 다릅니다. Intel P4를 AMD Opteron 마더 보드에 물리적으로 연결할 수 없음
Caleth

14
"BIOS"라는 용어는 PC의 "기본 입출력 시스템"을 나타내므로 BIOS가 x86 CPU를 의미합니다. IA64 시스템에는 BIOS 대신 EFI가 있고 PowerPC 시스템에는 Open Firmware 시스템 또는 독점 시스템이있을 수 있으며 Sparc 시스템에는 OFW (또는 OpenBoot)가 있으며 OLPC X0은 OFW를 사용하는 x86 기반 시스템입니다. PC에서도 더 이상 BIOS를 사용하지 않고 (U) EFI로 전환했습니다. OB / OFW는 휴대용 일뿐만 아니라 크로스 플랫폼으로 설계 되었기 때문에 흥미 롭습니다. OFW 드라이버는 모든 OFW 시스템에서 작동하며 CPU ISA와 상관없이 "Write Once Run Anywhere"입니다.
Jörg W Mittag

14
"오늘날 나는 대부분의 BIOS가 C ++로 작성되었다고 가정 할 것입니다."반드시 그런 것은 아닙니다. 사실 일 수도 있지만 그 업계에서 일하고 확실히 많은 부트 로더가 평범한 C로 작성되었습니다. 많은 것들이 종종 "Old Guard"이며 C ++을 완전히 신뢰하지 않는 경향이 있습니다.
Sam

6
@TomDworzanski : 기술적으로 BIOS (구 1981 년 PC 전용 제품)는 아니지만 IEEE-1275 개방형 펌웨어의 많은 구현 (Sparc의 PowerPC 공통 하드웨어 참조 플랫폼 (예 : PowerPC 공통 하드웨어 참조 플랫폼)과 유사한 역할에 사용됨) PowerMac, PowerBook), 100 $ 랩탑 OLPC X0-1)은 어셈블리 / C 이외의 언어로 부분적으로 작성되었습니다. OpenBoot , Open Firmware , OpenBIOS는 모두 다음을 포함합니다.
Jörg W Mittag

11

이론적으로는 모든 언어로 BIOS를 작성할 수 있지만, 현대는 대부분의 BIOS가 Assembly, C 또는이 둘의 조합을 사용하여 작성됩니다 .

BIOS는 실제 하드웨어 시스템에서 이해할 수있는 머신 코드로 컴파일 할 수있는 언어로 작성해야합니다 . 이것은 직접 또는 중간 해석 언어 (Perl, Python, PHP, Ruby, Java, C #, JavaScript 등)를 BIOS 작성에 적합한 것으로 제거합니다. (이론적으로는 정적 머신 코드로 직접 컴파일하거나 어떤 식 으로든 BIOS에 인터프리터를 내장하기 위해 이러한 언어 중 하나를 구현할 수 있습니다. 예를 들어 Java 용 포기 GCJ 프로젝트 가 있습니다.)

대부분의 OEM은 American MegatrendsPhoenix Techologies 같은 회사의 독점적 인 일반 BIOS 구현을 확장하여 BIOS를 구현합니다 . (아마도 그 회사 중 하나가 컴퓨터의 첫 부팅 화면에 표시되어있는 것을 보았을 것입니다.) 이러한 구현에 대한 소스 코드는 공개적으로 제공되지 않지만 일부 유출되었습니다. 나는 이것을 C 및 어셈블리 소스 코드에 직접 연결하고 싶지 않지만 인터넷 에이 소스 코드가 논의 되는 사람들을 위해 논의되는 곳이 있습니다.

고성능 및 게임 시장을 목표로하는 하드웨어 제조업체와 같은 일부 하드웨어 제조업체는 정확한 구현을 위해 설계된 사용자 지정 기능, 통계 및 매력적인 사용자 인터페이스로 BIOS 구현을 포화시킵니다. 이러한 기능 중 다수는 American Megatrends 및 기타 업체에서 생산 한 일반 제품에서 제공되는 기능을 뛰어 넘습니다. 불행히도, 이들 회사는 종종 소스 코드의 릴리스를 보안 위험으로 간주 하므로 이들 하이 엔드 구현에 대해서는 알려진 것이 거의 없습니다. 물론 그러한 BIOS 구현에 액세스하고 디 컴파일하는 방법을 찾을 수 있지만 그렇게하는 것은 어렵고 불법 일 수 있습니다.

원래 기계 코드를 생성해야하기 때문에 원래 질문으로 돌아가서 BIOS는 원시 기계 코드 컴파일러가 지원하는 프로그래밍 언어 로 구현되어야 합니다 . 그러한 언어가 많고 지난 수십 년 동안 확신 할 수 있지만 여러 언어가 실험에 사용되어 왔으며, 공개 된 모든 BIOS 구현은 C 및 / 또는 어셈블리의 조합에 구체적으로 의존합니다. 이 결론을 내리기 위해 살펴본 오픈 소스 BIOS 구현에는 OpenBIOS , tinyBIOS , coreboot , Intel BIOSLibreboot가 포함됩니다. 또한 오늘날에는 관련이 없지만 C 및 / 또는 어셈블리 규칙을 따르는 매우 오래된 BIOS 구현을 살펴 보았습니다.

하드웨어와 직접 상호 작용하도록 만들어진 다른 소프트웨어를 보는 것도 관련이 있다고 생각합니다. 예를 들어, Linux Kernel , OS X 커널Windows 커널 은 특정 작업에 대한 일부 어셈블리 및 일부 고급 언어를 사용하는 C입니다. 우리는 또한 알고 리눅스에서 하드웨어 드라이버Windows에서 하드웨어 드라이버는 C.에 크게 기록 된

BIOS로 돌아가서 선택한 프로그래밍 언어의 경제성을 고려하는 것도 중요하다고 생각합니다. BIOS는 일반적으로 하드웨어 판매를 보완하기 위해 필요합니다. 최신 BIOS 시스템은 C 및 / 또는 어셈블리로 크게 작성된 것으로 알려져 있습니다. 다른 도구로 이동하면 일반적으로 판매에 부정적인 영향을 줄 수있는 상품 제품으로 간주되는 비용에 상당한 비용이 추가됩니다. Economics 101에 들어 가지 않고도 OEM이 수십 년 동안 입증 된 검증 된 도구에서 벗어나는 것이 가치가 없다는 것을 확신 할 수 있습니다.

물론 BIOS를 작성하는 취미 프로젝트도 있습니다. 이것들도 지금까지 C 및 / 또는 어셈블리를 선택하는 것으로 보입니다. 아마도 언젠가 다른 기술이 사용될 것입니다. 그러나 오늘날의 선택은 잘 정의되어 있습니다.


4
약간의 nit-picking이지만 C #과 Java는 해석되지 않습니다. 바이트 코드로 컴파일됩니다. 그런 다음 인터프리터가 처리하는 바이트 코드입니다. 첫 번째 단락의 논리를 변경하지 않습니다.
Tonny

1
@ 토니 맞습니다. 좀 더 명확하게하기 위해 "직접 또는 중간 해석"을 추가했습니다.

@Tonny는 일반적으로 인터프리터가 아닌 지터로 특정 동적 기술을 사용하지 않는 한 모든 것을 기본으로 미리 맞추는 것이 가능하므로 중요한 차이점입니다. 따라서 이론적으로 .NET 언어 또는 Java로 BIOS를 작성하는 것이 이론적으로 가능할 것입니다. 둘 다 수행하고 필요한 모든 런타임 지원이 가능한지 확인하십시오. 그래도 그렇게하는 노력은 편의상 난장이 아니라고 생각합니다.
Jon Hanna

1
@Tonny 실제로 C #은 네이티브 코드 msdn.microsoft.com/en-us/vstudio/dotnetnative.aspx로 컴파일 되므로 약한 / 동적 언어 목록에서 보는 것이 이상합니다.
Den

@Den C #은 일반적으로 네이티브 코드로 컴파일 되지 않습니다 . 이 .Net Native 제품은 아직 공식적으로 출시되지 않았습니다. 내가 읽은 것부터 응용 프로그램 코드와 필요한 프레임 워크 코드를 실행 파일로 컴파일합니다. FAQ에 따르면 처음에 Windows 스토어 앱을 대상으로하므로보다 광범위하게 지원되는 데 시간이 걸릴 수 있습니다. 다시 말하지만, 모든 것이 잘되면 Microsoft가 가상 머신 모델에서 언젠가는 멀어 질 것 같습니다.

4

컴퓨터의 실제 BIOS는 아키텍처 종속 바이너리 코드로 컴파일 된 일부 언어 (아마도 C 또는 어셈블리)로 작성됩니다. 이 코드는 다른 아키텍쳐에서 실행될 수 없습니다 (그리고 아마도 그것이 제공되는 기계에 매우 구체적이기 때문에 실제로 필요하지는 않습니다).

그러나 옵션 ROM (GPU 옵션 ROM의 "비디오 BIOS"에서와 같이 BIOS라고도 함) 에 대해 생각하고 있습니까?

실제 레거시 BIOS 호환 옵션 ROM의 경우 아마도 ISA 종속 실행 가능 코드 일 것입니다 (다시 원하는 아키텍처를 대상으로 컴파일 할 수있는 모든 언어로 생성됨). PCI는 허용 여러 ISA들에 대한 포함 코드를 부팅 과정에서 해당 바이너리 이미지를 선택하는 호스트 할 수 있습니다.

UEFI 호환 옵션 ROM의 경우 다른 아키텍처에서 실행될 수 있는 아키텍처 독립적 바이트 코드 형식도 있지만 ISA 종속 코드도 계속 사용할 수 있습니다.

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.