디시인사이드 갤러리

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

갤러리 본문 영역

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

발명도둑잡기(118.216) 2025.12.10 20:57:54
조회 87 추천 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 48877 65
2907734 인지과학조져라 손발이시립디다갤로그로 이동합니다. 07:56 10 0
2907733 이미지 [단독] 선행매매로 112억 번 기자, 이투데이-서울경제-서울경제 ㅇㅇ(211.36) 07:34 7 0
2907732 해 낚시 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 07:32 10 0
2907731 태연 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 07:28 9 0
2907730 하루 한 번 헤르미온느 찬양 [1] 헤르 미온느갤로그로 이동합니다. 07:27 11 0
2907729 씨발년들아. 그래서 얼마나 많이 다중이 만들어써? 프갤러(202.9) 07:14 15 0
2907728 삼성에 프로그래머로 취직 햇는데 하루 12시간. MP4 [1] 마인츠05갤로그로 이동합니다. 06:38 39 0
2907727 OctoX is a radical Rust implementation 발명도둑잡기(118.216) 05:22 18 0
2907725 컴공 학부 4년 과정 독학하는데 얼마나 걸림? [3] 멍멍이(222.110) 02:23 63 0
2907724 고수가 되고 싶습니다 [1] 멍멍이(222.110) 02:21 30 0
2907723 이 정도면 어느 정도 수준인거임? 네카라쿠배 가냐 [3] 프갤러(115.91) 02:10 57 0
2907721 db 공부하다가 프갤러(210.94) 02:07 28 0
2907720 다당제 선거제도로 개혁 못하면 국민의힘이 정권교체 했을때 피해가 크다 발명도둑잡기(118.216) 01:38 24 0
2907718 베네수엘라 공격...마약 단속 아니라 석유 장악이 목적? 발명도둑잡기(118.216) 01:17 21 0
2907717 마동석은 되고 유승준은 안되는 진짜 이유 발명도둑잡기(118.216) 01:10 20 0
2907716 고슴도치케루빔이 666짐승 엘리베이터에 탑승한 테마음악 책사풍후zen갤로그로 이동합니다. 01:05 22 0
2907715 게임핵 방지프로그램, 바이러스 백신, DRM 등은 모두 빅브라더 기술이다 [1] 발명도둑잡기(118.216) 00:50 47 1
2907713 권도형 15년형 테라=포트녹스 금=달러=지니어스법=테더=써클 [2] 발명도둑잡기(118.216) 00:23 29 0
2907711 컴퓨터공학이 배우는게 뭐임? [3] 프갤러(106.241) 12.12 72 0
2907710 카메라 시장을 장악한 중국 발명도둑잡기(118.216) 12.12 28 0
2907709 이재명씨에게 개털리는 아저씨봐라 [1] 헬마스터갤로그로 이동합니다. 12.12 46 0
2907707 12월 러스트 순위 feat. 티오베 [3] 나르시갤로그로 이동합니다. 12.12 56 0
2907706 한국 여성 자살률, 남성보다 낮다?…"고위험군은 약 2배" 발명도둑잡기(118.216) 12.12 26 0
2907704 아이유 2025 AAA 발명도둑잡기(118.216) 12.12 20 0
2907703 동일본 대지진 성금 발명도둑잡기(118.216) 12.12 19 0
2907702 [슈퍼걸]1차 예고편 발명도둑잡기(118.216) 12.12 18 0
2907700 만4년차 연협 고민중이다 프갤러(118.235) 12.12 20 0
2907699 아랫집 청년이 층간소음으로 올라와서 목 조인 거 맞다니까요... [1] 넥도리아(119.195) 12.12 38 0
2907698 계엄 후 1년…반토막 난 성장률, 급등한 환율 발명도둑잡기(118.216) 12.12 17 0
2907697 그러고 보니 유튜브나 SNS, 커뮤도 블록체인과 닮은 면이 있네 chironpractor갤로그로 이동합니다. 12.12 22 0
2907696 광주도서관 붕괴됐대서 생각나는 예전 글 발명도둑잡기(118.216) 12.12 23 0
2907695 web3 개발자 있냐 백억대 프로젝트 할사람 [1] 프갤러(106.101) 12.12 41 0
2907694 국가보안법이 역사교과서를 왜곡한 결과 [5] 발명도둑잡기(118.216) 12.12 34 0
2907693 이준호 가고 박신혜 왔다…베일 벗으며 강렬한 첫인상 남긴 韓 드라마 발명도둑잡기(118.216) 12.12 32 0
2907692 틀딱 문과충들이 원래 한글에 집착함 [3] 헬마스터갤로그로 이동합니다. 12.12 36 0
2907691 [단독] 선행매매로 112억 번 기자, 이투데이-서울경제-서울경제TV 거 발명도둑잡기(118.216) 12.12 17 0
2907689 이게 대통령이 직접 지시해야 할 일이냐? [7] chironpractor갤로그로 이동합니다. 12.12 55 1
2907687 백악관, 중일갈등 '중립기어'…"트럼프, 양국정상과 좋은관계" 발명도둑잡기(118.216) 12.12 19 0
2907686 싱글벙글 포괄임금제 드디어 폐지 직전 발명도둑잡기(118.216) 12.12 21 0
2907685 익명 인터넷 Tor 프로그램 C에서 메모리 안전 언어 Rust로 전환 발명도둑잡기(118.216) 12.12 39 0
2907684 이런 악성 웹사이트 들어가버렸는데 [1] ㅇㅇ(125.181) 12.12 24 0
2907683 댓글공작원들은 자신의 전임자가 어떻게 암-살됐는지 물어보고 [1] 발명도둑잡기(118.216) 12.12 22 0
2907681 "그때 사살했어도 돼"‥김민수 역대급 막말 '파문' [1] 발명도둑잡기(118.216) 12.12 33 0
2907679 영화 <댓글부대> 관련 생각나는 예전 글 발명도둑잡기(118.216) 12.12 20 0
2907677 리액트 취약점 보고 있는데 개재밌네 프갤러(110.8) 12.12 49 0
2907676 오늘의 소설, 영화 실마리: 음악 감상 동아리 발명도둑잡기(118.216) 12.12 16 0
2907675 정신적으로 유아 상태인 좌빨들 특징 [2] 프갤러(110.8) 12.12 38 0
2907674 드라마 <프로보노> 관련 생각나는 예전 글 발명도둑잡기(118.216) 12.12 21 0
2907673 <모범택시> 관련 생각나는 예전 글 발명도둑잡기(118.216) 12.12 18 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2