본문 바로가기

All153

2023년 회고 2023년 회고 전역과 복학 2023년 3월, 드디어 군생활이 끝나고 3학년으로 복학했다. 전역신고를 하자마자 정신없이 학교로 달려가서 10시 수업을 들은 게 아직도 생생하다. 오랜만에 학교에 돌아오니 너무 반가웠다. 공부도 많이 하고 사람도 많이 만났던 것 같다. 1학기는 과제와 시험의 연속으로 정말 정신없이 흘러갔다. LSFMM 2023 & OSSNA 2023 참여 정말 꿈 같은 일주일 이었다. 감사하게도 LSFMMBPF Summit 2023에 초대되어서 Linux Foundation의 travel funding을 받고 컨퍼런스에 다녀왔다. OSSNA 2023도 같은 건물에서 진행해서 겸사겸사 다녀왔다. LSFMMBPF은 파일시스템, MM, BPF 서브시스템의 문제점과 향후 개발 계획을 논의하는 자리.. 2023. 12. 31.
PCIe Enumeration Introduction 펌웨어와 운영체제는 컴퓨터에 어떤 PCI(e) 디바이스들이 있는지 어떻게 발견할까? 이전 글에서는 ACPI MCFG 테이블과 PCI Function의 BDF 번호를 알면 특정 Function의 Configuration Space의 위치를 알 수 있다고 했다. 그런데 어떤 디바이스들이 컴퓨터에 연결되었는지를 먼저 알아야 Configuration Space를 읽든 말든 할 수 있다. 펌웨어와 운영체제는 부팅 직후 컴퓨터에 어떤 디바이스들이 있는지 알지 못한다. 부팅 직후 디바이스를 하나씩 발견하는 과정을 Enumeration이라고 한다. PCI Endpoint (Type 0) and Bridge (Type 1) Enumeration을 더 설명하기 전에 우리는 브리지에 관해 더 알아볼 .. 2023. 11. 30.
PCIe Configuration Space Bus, Device, Function Configuration Space와 Enumeration을 다루기 전에, BDF (Bus, Device, Function)이 무엇인지 알아보자. PCI와 PCIe에서는 PCI 도메인(or PCI 세그먼트)당 최대 256개의 버스가 존재할 수 있고, 버스당 최대 32개의 디바이스, 디바이스당 최대 8개의 펑션(function)이 존재할 수 있다. PCI(e) 시스템에서 (Bus, Device, Function)은 PCI 도메인 (or PCI 세그먼트) 내에서 디바이스를 식별할 수 있다. 리눅스에서는 'lspci' 명령어로 PCI(e) 디바이스의 B/D/F를 확인할 수 있다. PCI(e) Configuration Space 운영체제는 어떻게 디바이스와 상호작용할까? .. 2023. 11. 30.
An Introduction to PCI Express Introduction 컴퓨터 조립을 해봤다면 한 번쯤 PCIe에 대해서 들어봤을 것이다. 예를 들어서 "이 NVME SSD는 PCIe 4.0을 지원해서 높은 대역폭을 보여준다"던가 말이다. PCIe는 컴퓨터 시스템에 고성능 디바이스(GPU, 네트워크 카드 등)를 연결하기 위한 표준 인터페이스이다. 이 글은 PCIe가 무엇이고, 이전에 사용되던 PCI에서 어떻게 발전했는지를 다룬다. 또한 PCIe 시스템을 구성하는 루트 컴플렉스, 스위치, 브리지와 엔드포인트 등의 구성요소와 이것이 어떻게 소프트웨어에서 표현되는지를 다룬다. PCI vs. PCI Express PCIe (Peripheral Component Interconnect Express)는 프로세서와 디바이스, 혹은 디바이스와 디바이스가 통신하기 .. 2023. 11. 15.
anon_vma chaining (v2.6.34) Previously on rmap rmap (v2.5.27): pte chaining & page frame reclamation Introduction What is Reverse Mapping? 가상 메모리는 페이지 테이블을 사용해서 가상 주소를 물리 주소로 변환한다. 페이지 테이블은 프로세스별로 존재하며, 각각의 프로세스는 독립적인 가상 주소공간 hyeyoo.com Object-based reverse mapping (v2.6.7) Previously on rmap rmap (v2.5.26): pte chaining & page frame reclamation Introduction What is Reverse Mapping? 가상 메모리는 페이지 테이블을 사용해서 가상 주소를 물리 주소로 변환한다.. 2023. 2. 24.
Object-based reverse mapping (v2.6.7) Previously on rmap rmap (v2.5.26): pte chaining & page frame reclamation Introduction What is Reverse Mapping? 가상 메모리는 페이지 테이블을 사용해서 가상 주소를 물리 주소로 변환한다. 페이지 테이블은 프로세스별로 존재하며, 각각의 프로세스는 독립적인 가상 주소공간 hyeyoo.com 이전 글에서는 v2.5.27에 도입된 minimal rmap을 살펴봤다. pte chain 기반 rmap은 메모리 오버헤드와 fork/exit, page mapping/unmapping의 긴 실행 시간 때문에 머지 않아 object 기반 rmap에 의해 대체되었다. [4], [5] Some changes in pte chaining pt.. 2023. 2. 17.