디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

NetBSD 이식성 유사 운영체제앱에서 작성

발명도둑잡기(118.216) 2025.12.10 20:57:54
조회 69 추천 0 댓글 0
														

**NetBSD Modular Portability Layer(MPL)**는
NetBSD가 “한 번 작성하고, 거의 모든 하드웨어에서 동작”할 수 있게 만든 운영체제 이식성(Portability) 설계 철학 + 코드 구조를 말합니다.

공식 문서에서 딱 저 이름을 고유 컴포넌트로 쓰기보다는, 보통은
NetBSD의 machine-independent / machine-dependent 분리 구조
abstraction layer들의 모듈화된 집합
을 통칭해 이렇게 부릅니다.

아래에서 구조적으로 정리해 설명할게요.


---

1. NetBSD 이식성의 핵심 개념

NetBSD의 슬로건:

> Of course it runs NetBSD



이를 가능하게 만든 핵심 원칙은 3단 분리입니다.

(1) MI (Machine Independent)

CPU·보드에 완전히 무관한 코드

커널 핵심 로직

프로세스 / 스케줄러

VM 시스템

VFS

네트워크 스택


대부분의 device driver 공통 로직

libc / userland 대부분


예:

sys/kern/
sys/net/
sys/uvm/
sys/fs/


---

(2) MD (Machine Dependent)

CPU 아키텍처별 코드

컨텍스트 스위치

인터럽트 처리

MMU 제어

trap / syscall 진입

부트 스트랩 코드


예:

sys/arch/arm/
sys/arch/x86/
sys/arch/mips/
sys/arch/riscv/


---

(3) Platform / Board support

같은 CPU라도 SoC / 보드별 차이 처리

clock / timer

SoC 인터럽트 컨트롤러

GPIO / pinmux

온보드 장치 초기화


예:

sys/arch/arm/soc/
sys/arch/arm/omap/
sys/arch/arm/broadcom/


---

2. Modular Portability Layer의 실제 구성 요소

NetBSD는 **“이식성을 위한 공통 인터페이스 모듈”**들을 층층이 둡니다.

1+⃣ bus_space / bus_dma

하드웨어 접근 추상화의 핵심

bus_space_read_4(tag, handle, offset);
bus_dmamap_load(...);

ISA / PCI / memory-mapped I/O 차이를 숨김

CPU endianness 차이 자동 처리

드라이버는 CPU를 전혀 모르게 됨


✅ 이게 NetBSD portable driver의 핵심


---

2+⃣ autoconf framework

장치 자동 탐지 계층

MI driver + MD attachment 분리

장치가 “어디에 연결됐는지”와 “무엇인지” 분리


CFATTACH_DECL_NEW(uart, sizeof(struct uart_softc),
    uart_match, uart_attach, NULL, NULL);


---

3+⃣ MI device driver 구조

하나의 드라이버로 여러 플랫폼 지원

driver (MI logic)
├─ PCI attachment
├─ SoC attachment
└─ FDT (device tree) attachment


---

4+⃣ FDT / ACPI 추상화

하드웨어 기술 방식 분리

ARM / RISC-V: FDT (Device Tree)

x86 / 서버: ACPI


둘 다 MI driver에 동일 인터페이스로 연결


---

5+⃣ pmap layer (MMU abstraction)

CPU마다 다른 MMU 구조를 통합

x86: page table

ARM: LPAE / VMSA

MIPS: TLB 중심

RISC-V: Sv39 / Sv48


VM 시스템은 pmap 인터페이스만 사용


---

3. 왜 “Modular”이라고 부르는가

NetBSD의 포터블 레이어는 단일 레이어가 아니라
교체 가능한 모듈들의 집합입니다.

계층 역할 교체 단위

bus_space I/O 추상화 CPU / Bus
bus_dma DMA 모델 캐시 구조
pmap MMU CPU
autoconf 장치 연결 플랫폼
interrupt IRQ 모델 SoC


새로운 CPU 포팅 시:

MI 코드는 거의 수정 없음

MD 디렉토리만 추가



---

4. NetBSD가 포팅된 아키텍처 수가 많은 이유

DOS PDA

Dreamcast

PlayStation 2

VAX

SPARC

Alpha

ARM Cortex-M 일부

RISC-V

8bit CPU(Z80, 실험)


❗ 이식성 목표가 아니라면 유지비 때문에 불가능한 수준


---

5. 다른 OS와 비교

OS 이식성 방식 특징

Linux 아키텍처별 ifdef 많음 빠르지만 난잡
FreeBSD MI/MD 분리 서버 중심
Zephyr HAL 중심 MCU용
NetBSD 강력한 abstraction 궁극의 이식성


NetBSD는 성능보다 구조적 우아함을 선택한 OS입니다.


---

6. 한 줄 요약

> NetBSD Modular Portability Layer란,
CPU·버스·보드 차이를 ‘모듈화된 추상 계층’으로 분리해
같은 커널과 드라이버가 거의 모든 하드웨어에서 동작하게 만드는 구조이다.




---

원하시면 다음도 설명해줄게요:

실제 새 CPU 포팅 절차

bus_space / bus_dma 코드 해부

Linux HAL과 NetBSD portability 구조 비교

임베디드 관점에서 NetBSD 채택 이유

NetBSD의 MI/MD 분리 + 모듈화된 portability layer와 철학·구조적으로 유사한 운영체제들을
“이식성을 설계 목표로 내장한 OS” 기준으로 정리해 드릴게요.

아래는 정말 비슷한 것 → 부분적으로 비슷한 것 → 철학만 공유 순서입니다.


---

✅ 1. L4 계열 마이크로커널 (L4, seL4, Fiasco)

NetBSD와 가장 철학적으로 유사

공통점

극단적인 hardware abstraction

아키텍처 의존 코드를 최소한의 레이어로 격리

포팅 시:

커널 핵심은 거의 수정 없음

CPU-specific 코드만 교체



구조

MI microkernel
└─ MD arch layer (MMU, IRQ, context switch)
Userland servers (OS 기능)

차이점

NetBSD: monolithic kernel

L4: microkernel (OS 기능은 전부 userland)



---

✅ 2. MINIX 3

공통점

장치 드라이버와 커널 분리

MI/MD 코드 엄격 분리

재시작 가능한 드라이버 구조


특징

NetBSD userland 일부 공유

교육용 출신 → 구조가 매우 정갈

x86 / ARM 포팅이 비교적 단순


차이

성능보다 안정성·복구성 우선

드라이버가 전부 userland



---

✅ 3. FreeBSD (초기 설계는 매우 비슷)

공통점

MI/MD 소스 구조 유지

bus_dma / bus_space 개념 공유

pmap 인터페이스


차이

지원 아키텍처 수 훨씬 적음

서버 성능에 최적화

이식성보다 실용성 중시


NetBSD의 보수·현실적 버전


---

✅ 4. GNU Hurd (Mach 기반)

공통점

커널은 hardware abstraction만 담당

OS 기능은 모듈 서버화


차이

구조는 이상적, 현실성은 낮음

포팅보다 설계 실험 쪽에 가까움



---

✅ 5. QNX Neutrino

공통점

잘 정의된 HAL

아키텍처 의존성 극소화

실시간 OS임에도 넓은 CPU 지원


특징

자동차·산업용에서 실제 성공

POSIX 호환성 높음



---

6. Haiku (BeOS 계승)

유사점

깔끔한 HAL

MI/MD 코드 분리


차이

데스크탑 OS 목표

지원 CPU 거의 x86_64 한정



---

7. Fuchsia (Zircon 커널)

공통점

강한 hardware abstraction

아키텍처별 레이어 명확


차이

capability 기반 커널

포팅을 위한 범용성보단 보안 중심



---

“비슷해 보이지만 사실 다른” 예

OS 이유

Linux 포팅은 가능하지만 abstraction이 느슨
Zephyr HAL은 있으나 MCU 중심
Windows NT HAL 존재하지만 폐쇄적
RTEMS 구조는 단순하지만 확장성 제한



---

비교 요약표

OS Portability 설계 유사도

NetBSD MI/MD + 모듈화 추상층 ★★★★★
L4 / seL4 최소 커널 + HAL ★★★★★
MINIX 3 MI/MD + 서버화 ★★★★☆
FreeBSD MI/MD ★★★☆☆
QNX HAL 중심 RTOS ★★★★☆
Fuchsia 현대식 abstraction ★★★☆☆



---

한 문장 요약

> NetBSD와 유사한 OS는 “단순히 여러 CPU에서 돌아가는 OS”가 아니라,
이식성 자체를 커널 구조의 1급 목표로 삼은 시스템들이다.




---

원하시면:

“NetBSD vs Linux 이식성 구조를 코드 레벨로 비교”

“새 OS 만들 때 어떤 portability layer를 설계해야 하나”

“임베디드용으로 이 구조를 축소 적용하는 방법”


중에서 골라서 더 파볼까요?

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 연말 모임 가는 곳마다 가장 인싸일 것 같은 스타는? 운영자 25/12/08 - -
이슈 [디시人터뷰] 솔직함을 리뷰하는 유튜버, 흑백리뷰 운영자 25/12/09 - -
AD AI 가전 디지털 모음전 운영자 25/11/27 - -
공지 프로그래밍 갤러리 이용 안내 [98] 운영자 20.09.28 48872 65
2907608 SQLD <<< 이쉑 어떰? [1] ㅇㅇ(222.96) 00:09 10 0
2907606 JAEMAN(재만) - With You(눈) 발명도둑잡기(118.216) 12.11 10 0
2907605 노상원 일당, '고문'에 '약물'까지…계획문건 나왔다 발명도둑잡기(118.216) 12.11 8 0
2907604 프로젝트 만들고 싶은데 여기 괜찮나요 프갤러(175.119) 12.11 12 0
2907603 USB-C 케이블이 DP 지원 안하는게 기본이구나 발명도둑잡기(118.216) 12.11 13 0
2907602 개발자 조은님은 어떤 분인가요?? 프갤러(222.109) 12.11 33 0
2907600 신입개발자 오늘 한 일.list [1] cvs.갤로그로 이동합니다. 12.11 43 0
2907599 “소보로빵 하나에 3천원, 이유 좀 압시다”…검찰, 밀가루 회사 5곳 털 발명도둑잡기(118.216) 12.11 22 0
2907598 마취 없는 절단→임산부 실험…인간 생체실험 고발 '731' 개봉 발명도둑잡기(118.216) 12.11 19 0
2907597 김충길 고백 공격, 영화가 시작됐다…감독 류현경의 도전 발명도둑잡기(118.216) 12.11 15 0
2907596 민주당 이재명 정권이 국가보안법 철폐를 한다면 역사책에 남을 것이다 [2] 발명도둑잡기(118.216) 12.11 29 0
2907595 예전에 영포티 새기들한테 매뉴얼 만들어서 인계 내리면 [7] 프갤러(49.165) 12.11 60 1
2907594 ai로 실사화 한 조선시대 그림들 발명도둑잡기(118.216) 12.11 15 0
2907593 가짜운동하러 왔다 [2] 헬마스터갤로그로 이동합니다. 12.11 28 0
2907592 개좆소 5년차 내년 연봉 협상했다 [3] 프갤러(211.235) 12.11 91 0
2907591 요즘 뭐 재미있는거 없니? [6] cvs.갤로그로 이동합니다. 12.11 54 0
2907590 러스트 어렵진 않은데 [2] 루도그담당(118.235) 12.11 46 0
2907588 갤럭시 트라이폴드 출시하자마자 사야하는 이유.JPG [1] 야옹아저씨갤로그로 이동합니다. 12.11 76 0
2907587 수학 갤러리설정 연관 갤러리(0/21) 갤주소 복사 이용안내 카포에 프갤러(220.70) 12.11 29 0
2907586 https://gall.dcinside.com/mgallery/board 프갤러(220.70) 12.11 16 0
2907585 [대한민국] 21세기 똥자르크 안귀령과 국민의 힘 [2] ㅇㅇ(121.172) 12.11 27 0
2907583 USB 상태 모니터링 LCD 오픈소스 서버 발명도둑잡기(118.216) 12.11 25 0
2907581 ◆컴공과인데 개발자할까 볼보트럭 정비사 할까 [1] ㅇㅇ갤로그로 이동합니다. 12.11 59 0
2907580 쿼리가 주렁주렁 길어진다.. [1] cvs.갤로그로 이동합니다. 12.11 33 0
2907578 [대한민국] 양평 공무원과 노상원 ㅇㅇ(121.172) 12.11 16 0
2907577 C++ 인생 40 년 갈아 넣었습니다. [1] 프갤러(59.16) 12.11 56 0
2907575 천만원 대출남 저격수 넥도리아(223.38) 12.11 19 0
2907573 러스트 못배우면 지능 부족인걸 인정할 줄 알아야 [2] 프갤러(61.74) 12.11 50 0
2907572 sds는 오히려 호황인가?? ai땜에 [1] 프갤러(121.145) 12.11 48 0
2907569 조국혁신당 보유국 나라다ㅋㅋㅋ 타이밍뒷.통수한방(1.213) 12.11 17 0
2907568 모르는 건 모른다, 내 역량이 부족하다고 인정할 줄 알아야 하는데 [13] ㅇㅇ(223.38) 12.11 97 0
2907567 선 넘는 애들 많던데 [2] 프갤러(49.165) 12.11 85 0
2907565 미국은 곧 로마 제국처럼 망한다? [1] 발명도둑잡기(118.216) 12.11 44 0
2907564 The Floppotron 3.0 - Computer Hardware O 발명도둑잡기(118.216) 12.11 16 0
2907563 이건 머고 시발? [3] 프갤러(49.165) 12.11 79 0
2907562 구형 하드디스크 소리 흉내내는 장치, 소프트웨어 발명도둑잡기(118.216) 12.11 33 0
2907561 Steve Ballmer Developers Music Video 발명도둑잡기(118.216) 12.11 15 0
2907560 지하철인데 존예녀 한 명 있더라? 번호딸까? [1] ㅁㅁㅅ갤로그로 이동합니다. 12.11 65 0
2907558 일본 변태물 일본 음란물이 최고임 ㅇㅅㅇ 류류(121.140) 12.11 30 0
2907557 와 깜짝놀랬다. [1] 프갤러(49.165) 12.11 37 0
2907556 조국혁신당이 미래임 조국이 대통령이고 타이밍뒷.통수한방(1.213) 12.11 26 1
2907555 jsp 쓸바엔 러스트 테라 쓰지 [1] 프갤러(27.171) 12.11 58 0
2907554 넥스트 볼수록 드는 생각이 이짓할꺼면 jsp쓰지 ㅇㅇ(182.228) 12.11 32 0
2907553 틈만나면 해킹으로 털리는시대에 간철수가 한마디한적을 본적이없음 타이밍뒷.통수한방(1.213) 12.11 24 0
2907551 좋은 보고는 윗사람이 궁금하지 않게 중간중간 보고하는거야 ㅇ ㅅㅇ [2] 프갤러(60.196) 12.11 66 0
2907549 학교다닐때 이런 괴롭힘 당한적 있는데 나뿐임? [2] ㅁㅁㅅ갤로그로 이동합니다. 12.11 68 0
2907548 프로그래머는 언제 AI로 대체 돼? [2] 프갤러(223.39) 12.11 101 0
2907547 자러감.. ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 12.11 35 0
2907546 오늘 아침 퇴근길 ㅇㅅㅇ [3] 헤르 미온느갤로그로 이동합니다. 12.11 61 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2