디시인사이드 갤러리

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

갤러리 본문 영역

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

발명도둑잡기(118.216) 2025.12.10 20:57:54
조회 91 추천 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 - -
AD AI 가전 디지털 모음전 운영자 25/11/27 - -
공지 프로그래밍 갤러리 이용 안내 [98] 운영자 20.09.28 48885 65
2907791 join을 exist로 바꾸거나 그 반대로 했을때 슈퍼막코더(126.33) 00:08 6 0
2907790 일본인 연락속도 질문 [1] ㅈㅈ(211.216) 12.13 10 0
2907789 [애니뉴스] Worker Pool ㅇㅇ(121.172) 12.13 7 0
2907787 카톡프사 이렇게 했는데 혹시 십덕같아보여? ㅁㅁㅅ갤로그로 이동합니다. 12.13 14 0
2907786 요즘은 사람 뽑을 때 보는게 다양해졌구나 ㅇㅇ(211.234) 12.13 11 0
2907785 너네 김대기 아냐? [1] 프갤러(121.153) 12.13 16 0
2907784 솔직히 컴공은 예전부터 추천받는 학과는 아니었음 박민준갤로그로 이동합니다. 12.13 27 1
2907783 살릴 수 있을까요? 컴퓨터 수리 넥도리아(220.74) 12.13 19 0
2907781 개발에 학벌 중요함? 방통대 졸업해도 ㄱㅊ?? [1] ㅇㅇ(223.39) 12.13 26 0
2907779 요즘 컴공과 입결도 낮아지고 미래도 어두움 ㅇㅇ(183.106) 12.13 32 0
2907778 ai 있으면 어느정도까지 해봐야지 실력임? [1] 프갤러(58.76) 12.13 30 0
2907777 조국혁신당이 미래다 이기이기 타이밍뒷.통수한방(1.213) 12.13 10 0
2907776 이재명 대통령이 미제의 하수인인 지배-예속 관계 발명도둑잡기(118.216) 12.13 21 0
2907775 음기 충전 발명도둑잡기(118.216) 12.13 20 0
2907774 "적자 나도 1000원"… 고려대 명물 '영철버거' 이영철씨 별세 발명도둑잡기(118.216) 12.13 17 1
2907772 백엔드갤 특정 회사 몇명 친목질 [2] ㅇㅇ(182.210) 12.13 39 0
2907771 나는 수집가였고, 안양에 있는 학교의 비리를 캤다 넥도리아(220.74) 12.13 18 0
2907770 "엄마 전 재산 다 날렸다"…보이스피싱에 무너진 가족 발명도둑잡기(211.235) 12.13 19 0
2907769 프갤러랑 오프했다... [7] ^으^갤로그로 이동합니다. 12.13 50 0
2907768 세계 인권의 날 발명도둑잡기(211.234) 12.13 11 0
2907766 중고폰 연락 기다립니다. 넥도리아(119.195) 12.13 18 0
2907765 "도무지 이해할 수 없다" 롯데백화점에 돌직구 던진 시민들 발명도둑잡기(39.7) 12.13 21 0
2907764 ai 나왔는데 실력이 뭔 의미가있냐 ㅋㅋ ㅇㅇ(175.196) 12.13 42 0
2907763 개발 공부 하던 애가 문돌이 공무원 사무직 하면 미쳐버리지 않음? 멍멍이(222.110) 12.13 21 0
2907762 프갤러들 다 쳐바르는 실력 되려면 얼마나 걸립니까? [4] 멍멍이(222.110) 12.13 37 0
2907761 이쁜 여자로 갈비탕 해먹고싶은데 어떰? [1] ㅁㅁㅅ갤로그로 이동합니다. 12.13 42 0
2907760 ◆컴공졸인데 지금상황에 개발자할까 트럭정비사할까 [1] ㅇㅇ갤로그로 이동합니다. 12.13 56 0
2907759 공공기관용 운영관리 프로그램 같은건 뭐로 작성된거임? [1] 123(121.175) 12.13 37 0
2907758 웹소켓 부분 어렵네 [2] 프갤러(58.76) 12.13 50 0
2907757 ‘공부 말고 등산하면 장학금 준다’···카이스트에 생긴 이색 장학금 발명도둑잡기(39.7) 12.13 18 0
2907756 내란특검, 김용현 추가 기소…"HID요원 등 명단 노상원에 넘겨" 발명도둑잡기(39.7) 12.13 16 0
2907755 한국도 참여한 미국 주도 AI 동맹 "비시장적 관행에 공동 대응" 발명도둑잡기(39.7) 12.13 24 0
2907754 독재정권도 벌벌 떨게 만든 '행동대장' 엄마들 발명도둑잡기(39.7) 12.13 23 0
2907753 아 이렇게 거지같이 살 다간 진짜 안좋은 생각할듯.. ㅇㅇ(1.244) 12.13 21 0
2907752 “일본인 멤버 빼고 와”…중일 갈등에 케이팝 날벼락 발명도둑잡기(39.7) 12.13 22 0
2907751 “더러운 머리 잘라라”…中, 日 난징대학살 겨냥 포스터 공개 발명도둑잡기(39.7) 12.13 24 0
2907750 겁나 아버지 의심해서 교통안전 표지판 cctv 겁나 찍고 다녔다. [3] 넥도리아(119.195) 12.13 53 0
2907749 국민의 근심 발명도둑잡기(39.7) 12.13 13 0
2907748 블로그 사이트 다들 어디꺼써?? [11] ㅇㅇ(121.140) 12.13 80 0
2907747 내 여친 사진임 ㄱㅊ? ㅁㅁㅅ갤로그로 이동합니다. 12.13 86 0
2907745 '탄핵 반대' 윤상현 "1년 후 다 찍어주더라" 발명도둑잡기(39.7) 12.13 28 0
2907744 ‘전기 헤드셋’으로 우울증 치료한다…FDA 승인에 내년 출시 발명도둑잡기(39.7) 12.13 17 0
2907743 "중·러 폭격기 도쿄 방향으로 날아‥이례적" 발명도둑잡기(39.7) 12.13 25 0
2907742 윤석열이 열어젖힌 '오버턴 창' 발명도둑잡기(118.216) 12.13 16 0
2907741 지금까지 이런 기업은 없었다…남다른 ‘김범석의 쿠팡’ 발명도둑잡기(118.216) 12.13 21 0
2907740 이스라엘이 키운 가짜 영웅, 내부 총질 와중에 횡사하다 발명도둑잡기(118.216) 12.13 24 0
2907739 트럼프·빌 게이츠·클린턴까지... 미 민주당, 엡스타인 사진 공개 발명도둑잡기(118.216) 12.13 50 0
2907738 한학자 "민주당 축복 못하겠다"…'양쪽 어프로치' 통일교 변심 왜 발명도둑잡기(118.216) 12.13 27 0
2907737 내란세력 윤어게인의 나라는 망해도 됩니다 발명도둑잡기(118.216) 12.13 19 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2