Linux에서 파일 시스템 드라이버 드라이버를 어떻게 구현합니까? [닫은]


15

새 파일 시스템을 발명했다고 가정하고 파일 시스템 드라이버를 작성하려고합니다.

이 파일 시스템 드라이버를 어떻게 구현합니까? 이것은 커널 모듈을 사용하여 수행됩니까?

그리고 파일 시스템 드라이버가 하드 디스크에 액세스하는 방법, 파일 시스템 드라이버에 하드 디스크에 액세스하는 코드가 포함되어 있거나 Linux에 모든 파일 시스템 드라이버가 사용하는 하드 디스크에 액세스하는 장치 드라이버가 포함되어 있습니까?

답변:


24

예, Linux의 파일 시스템은 커널 모듈로 구현할 수 있습니다. 그러나 일반 사용자 공간 프로세스가 파일 시스템 드라이버로 작동 할 수있는 FUSE (USErspace의 파일 시스템) 인터페이스도 있습니다. 새 파일 시스템을 프로토 타이핑하는 경우 먼저 FUSE 인터페이스를 사용하여 구현하면 테스트 및 개발이 쉬워 질 수 있습니다. 파일 시스템의 내부가 FUSE 형식으로 작동하면 성능 최적화 커널 모듈 버전의 구현을 시작할 수 있습니다.

다음은 커널 공간 내에서 파일 시스템을 구현하는 데 대한 기본 정보입니다. 그것은 오래되었지만 (1996 년부터!) 적어도 당신이해야 할 일에 대한 기본 아이디어를 제공해야합니다.

FUSE 라우트로 이동하기로 선택한 경우 FUSE 인터페이스의 사용자 공간 측에 대한 참조 구현 인 libfuse가 있습니다.

커널 모듈로서의 파일 시스템 드라이버

기본적으로 파일 시스템 드라이버 모듈의 초기화 함수는 함수를 호출하기 만하면되고 register_filesystem()파일 시스템을 식별하는 첫 번째 단계로 사용될 파일 시스템 드라이버의 함수를 식별하는 함수 포인터를 포함하는 구조를 매개 변수로 제공하면됩니다. 유형과 장착. 이 단계에서는 더 이상 발생하지 않습니다.

파일 시스템이 마운트되고 파일 시스템 유형이 드라이버와 일치하도록 지정되거나 파일 시스템 유형 자동 감지가 수행되는 경우 커널의 가상 파일 시스템 (VFS) 계층이 해당 기능을 호출합니다. 기본적으로 "표준 Linux 블록 장치의 커널 수준 표현에 대한 포인터가 있습니다. 살펴보고 처리 할 수 ​​있는지 확인한 다음 수행 할 수있는 작업을 알려주십시오."

이 시점에서 드라이버는 파일 시스템에 적합한 드라이버인지 확인한 다음 드라이버가 해당 특정 파일 시스템으로 수행 할 수있는 추가 기능에 대한 포인터를 포함하는 구조를 반환해야합니다. 또는 파일 시스템 드라이버가 디스크의 데이터를 인식하지 못하면 적절한 오류 결과를 반환해야하며 VFS는 사용자 공간에 오류를보고하거나-파일 시스템 유형 자동 감지가 수행되는 경우 다른 파일 시스템을 요청합니다 시도하는 운전사.

커널의 다른 드라이버는 표준 블록 장치 인터페이스를 제공하므로 파일 시스템 드라이버는 하드웨어 지원을 구현할 필요가 없습니다. 기본적으로 파일 시스템 드라이버는 표준 커널 수준 기능을 사용하여 장치 포인터를 사용하여 디스크 블록을 읽고 쓸 수 있습니다.

VFS 계층은 파일 시스템 드라이버가 VFS 계층에 다양한 표준 기능을 제공 할 것으로 예상합니다. VFS 계층이 파일 시스템에서 의미있는 작업을 수행하기 위해 이들 중 일부는 필수이며, 다른 것은 선택적이며 이러한 선택적 함수에 대한 포인터 대신 NULL을 반환 할 수 있습니다.


1
이것은 블록 장치 계층이 파일 시스템 계층을 기반으로 제공하는 기능에 대해 조금 말해야 할 것처럼 질문에 완전히 대답하기에 좋은 대답입니다.
kasperd

나는 "표준 블록 장치에 대한 포인터가 있습니다"라는 비트를 사용하여 그 점을 언급했지만 좋은 지적입니다. 나는 그것을 확장했다.
telcoM

이 대답, 특히 어떤 순서로 일어나는 일에 대한 설명은 신성합니다. 내가 읽을 수있는 일종의 서적 / 웹 사이트가 있습니까? "리눅스 작동 방식"에 대한 설명이 있습니까?
Adam Barnes

Linux Kernel Internals 또는 Linux Device Drivers, 3rd Edition에 관심이있을 수 있습니다 . 물론 실제 소스 코드를 읽는 옵션도 있습니다.
telcoM


0

예. 이것은 일반적으로 커널 모듈로로드되거나 커널로 컴파일 될 수있는 커널 드라이버를 사용하여 수행됩니다.

비슷한 파일 시스템 드라이버와 작동 방식을 확인할 수 있습니다 .

이러한 드라이버는 내부 커널 기능을 사용하여 저장 장치에 바이트 블록으로 액세스 할 수 있지만 블록 장치문자 장치 폴더의 드라이버에 의해 노출 된 블록 장치를 사용할 수도 있습니다 .


0

퓨즈를 사용하여 사용자 랜드 파일 시스템을 만들거나 커널 모듈을 작성할 수 있습니다. 언어를 선택할 수 있으므로 퓨즈를 사용하는 것이 더 쉽고 커널 (및 전체 시스템)에 충돌을 일으키지 않습니다.

커널 모듈은 더 빠를 수 있지만 최적화의 첫 번째 규칙은 다음과 같습니다. 작업 코드를 테스트 할 때까지 수행하지 마십시오. 두 번째는 그것과 같습니다. 너무 느리다는 증거가 나타날 때까지하지 마십시오. 그리고 세 번째 : 더 빠르거나 작게 만든다는 증거가 없다면 보관하지 마십시오.

그리고 그렇습니다. 커널에는 이미 하드웨어 용 드라이버가 있습니다. 다시 구현하지 마십시오.


성능 이외의 FUSE에는 단점이 있습니다. 루트 파일 시스템에는 사용하기 어렵습니다. (initrd로 가능할 수도 있지만 FRAM 바이너리는 여전히 램 디스크에서 실행되기 때문에 부팅 후 해제 할 수 없습니다.)
Peter Cordes

1
@PeterCordes 해제 할 수 없지만 연결을 해제 할 수는 없습니다. 그래도 참조가 있다면 initramfs를 떠나서 기본 바이너리를 삭제했는지 여부에 관계없이 메모리에 유지됩니다.

@forest : 맞습니다. 따라서 pivot_rootinitramfs에 여전히 사용중인 inode가 있기 때문에 initrd를 마운트 해제 할 수 없습니다 .
Peter Cordes

/initinitramfs에서 시작된 normal 은 /initpivot_root 다음에 실행되어 제어를 실제 루트 FS로 전달 /init합니다. 그러나 루트 FS에 대한 액세스가 커널에 응답하는 FUSE 프로세스에 의존하는 경우 FUSE 이진 파일을 execve로 바꿀 수 없습니다. 아마도 페이지 캐시를 먼저 프라이밍하여 신뢰할 수는 없습니다.
Peter Cordes
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.