Linux 커널 모듈은 운영체제의 핵심 기능을 확장하거나 추가하기 위해 설계된 코드 조각입니다. 이러한 모듈은 C 언어로 작성되며, 시스템 내 다른 구성 요소와의 상호작용을 위해 의존성과 라이선스 정보를 명확히 지정해야 합니다. 특히, MODULE_LICENSE
는 커널 모듈이 적합한 라이선스 정책을 따르고 있는지 확인하는 데 중요한 역할을 합니다. 이 기사에서는 커널 모듈의 의존성과 MODULE_LICENSE
의 중요성과 활용 방법을 탐구합니다.
커널 모듈의 의존성이란?
커널 모듈의 의존성이란 특정 모듈이 동작하기 위해 필요한 다른 모듈이나 커널 컴포넌트를 의미합니다. Linux 커널은 계층화된 구조를 가지며, 각 모듈은 필요에 따라 다른 모듈이나 라이브러리 함수에 의존합니다.
의존성의 종류
- 내부 의존성: 다른 커널 모듈에 대한 의존성으로, 하나의 모듈이 다른 모듈의 기능을 호출하거나 데이터를 공유할 때 발생합니다.
- 외부 의존성: 특정 하드웨어 드라이버나 라이브러리가 필요한 경우 발생하는 의존성입니다.
의존성 문제의 중요성
- 정상적인 로드: 의존성이 제대로 관리되지 않으면 모듈이 커널에 로드되지 않거나 충돌을 일으킬 수 있습니다.
- 디버깅 어려움: 의존성 충돌은 복잡한 디버깅 과정을 요구하며 시스템 불안정성을 유발할 수 있습니다.
- 호환성 유지: 의존성을 명확히 정의하면 커널 업데이트나 환경 변경 시에도 모듈이 안정적으로 동작합니다.
적절한 의존성 관리는 커널 모듈 개발의 필수 요소로, 개발 초기부터 이를 고려해야 합니다.
의존성을 올바르게 관리하는 방법
커널 모듈의 의존성을 적절히 관리하면 시스템의 안정성과 호환성을 유지할 수 있습니다. 이를 위해 Linux 커널에서 제공하는 여러 도구와 규칙을 활용할 수 있습니다.
1. `modinfo`를 통한 의존성 확인
modinfo
명령어를 사용하여 특정 모듈의 의존성을 확인할 수 있습니다. 예를 들어:
modinfo <모듈 이름>
이 명령은 해당 모듈의 종속 관계를 포함한 메타데이터를 표시합니다.
2. `MODULE_DEPENDS` 매크로 활용
커널 모듈 코드에서 MODULE_DEPENDS
매크로를 사용하여 특정 모듈이 필요로 하는 의존성을 명시적으로 정의할 수 있습니다.
MODULE_DEPENDS("dependency1, dependency2");
3. `depmod` 명령어를 사용한 의존성 매핑
depmod
는 커널 모듈 의존성을 자동으로 분석하고 필요한 모듈 간 관계를 생성합니다.
depmod -a
이 명령은 /lib/modules/<커널 버전>/modules.dep
파일에 의존성 정보를 작성합니다.
4. 의존성 로드 순서 관리
의존성이 있는 모듈은 올바른 순서로 로드해야 합니다. 이를 위해 modprobe
명령어를 사용하는 것이 권장됩니다.
modprobe <모듈 이름>
modprobe
는 의존성에 따라 필요한 모듈을 자동으로 로드합니다.
5. Makefile에서 의존성 관리
모듈 빌드 시 Makefile을 통해 의존성을 관리할 수 있습니다.
obj-m += my_module.o
my_module-objs := file1.o file2.o
이는 모듈이 여러 파일로 구성된 경우 의존성을 정의합니다.
6. 동적 로딩과 정적 로딩
- 동적 로딩: 필요한 경우에만 모듈을 로드하여 메모리 사용을 최적화합니다.
- 정적 로딩: 커널 빌드 시 모듈을 통합하여 성능과 안정성을 높입니다.
실전 팁
- 의존성을 정의할 때는 항상 필요한 최소한의 모듈만 명시합니다.
- 커널 모듈 버전 호환성을 테스트하여 의존성 충돌을 사전에 방지하십시오.
올바른 의존성 관리는 커널 모듈의 안정적인 작동을 보장하고, 시스템 유지보수를 간소화합니다.
MODULE_LICENSE의 역할
Linux 커널 모듈 개발에서 MODULE_LICENSE
는 모듈의 라이선스를 명시하기 위해 사용됩니다. 이는 커널이 모듈의 적합성을 확인하고, 커널의 GPL 라이선스 정책과 호환되는지 평가하는 데 중요한 역할을 합니다.
1. `MODULE_LICENSE`의 정의
MODULE_LICENSE
는 커널 모듈 코드 내에서 다음과 같이 사용됩니다.
MODULE_LICENSE("GPL");
이 매크로는 커널에 모듈의 라이선스 정보를 제공하여 모듈 로드 여부를 결정합니다.
2. 주요 역할
- 커널과의 호환성 확인
MODULE_LICENSE
는 모듈이 GPL 라이선스 또는 기타 허용된 라이선스를 준수하는지 확인합니다.
- GPL 호환 라이선스가 아닌 경우, 커널은 해당 모듈을 비GPL로 간주하고 경고 메시지를 출력합니다.
- 법적 준수 보장
오픈소스 프로젝트인 Linux 커널의 라이선스 정책을 준수하여, 비GPL 모듈이 커널의 심층적인 API를 호출하지 않도록 보장합니다. - 로드 정책 결정
- GPL 또는 호환 라이선스가 지정된 경우: 모듈이 커널에 정상적으로 로드됩니다.
- 비GPL 라이선스가 지정되거나 누락된 경우: 커널은 “taint” 상태로 표시하며, 이는 시스템 진단 및 디버깅 시 영향을 미칩니다.
3. 커널 로드 시 출력 예
MODULE_LICENSE
가 적절히 지정되었을 때와 누락되었을 때의 dmesg 출력 예:
- 적절히 지정된 경우
[Kernel Message] Module loaded successfully.
- 누락된 경우
[Kernel Warning] Kernel tainted: Non-GPL module loaded.
4. 라이선스 정보의 중요성
MODULE_LICENSE
는 단순한 메타정보 이상의 역할을 하며, 다음과 같은 이유로 필수적입니다.
- 커널 개발자 및 사용자가 모듈의 법적 상태를 명확히 이해할 수 있음
- GPL 라이선스를 기반으로 하는 커널과의 신뢰성을 유지
5. 실제 코드에서의 사용
예제 코드:
#include <linux/module.h>
#include <linux/kernel.h>
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Developer Name");
MODULE_DESCRIPTION("Example Kernel Module");
int init_module(void) {
printk(KERN_INFO "Module initialized.\n");
return 0;
}
void cleanup_module(void) {
printk(KERN_INFO "Module removed.\n");
}
MODULE_LICENSE
는 커널과 모듈 간의 상호작용을 규정하며, 커널 모듈 개발의 핵심적인 구성 요소입니다. 이를 통해 모듈 로드의 적합성과 법적 준수를 동시에 보장할 수 있습니다.
MODULE_LICENSE에 지정 가능한 값들
MODULE_LICENSE
는 커널 모듈이 사용하는 라이선스를 명시하며, 지정 가능한 값에 따라 커널이 모듈을 처리하는 방식이 달라집니다. 각 값은 모듈의 라이선스 유형과 커널 정책 간의 적합성을 정의합니다.
1. 주요 허용 값
다음은 커널이 인식하는 주요 MODULE_LICENSE
값과 그 의미입니다.
- “GPL”
- GNU General Public License (GPL)를 따르는 라이선스입니다.
- 커널과 완벽히 호환되며, 모든 커널 API를 사용할 수 있습니다.
- “GPL v2”
- GPL 버전 2를 따르는 라이선스입니다.
- Linux 커널은 GPL v2를 기반으로 하므로 완전한 호환성을 제공합니다.
- “Dual BSD/GPL”
- BSD와 GPL의 이중 라이선스를 따르는 모듈입니다.
- GPL 호환으로 간주되며, 커널 로드에 제한이 없습니다.
- “Dual MIT/GPL”
- MIT와 GPL의 이중 라이선스를 사용하는 모듈입니다.
- GPL 호환으로 간주됩니다.
- “Proprietary”
- 비GPL 상용 라이선스를 나타냅니다.
- 커널은 모듈을 로드하지만, 시스템 상태를 “tainted(오염됨)”로 표시합니다.
2. 그 외의 값
- “BSD”
- BSD 라이선스 단독 사용을 나타냅니다.
- GPL과의 호환성을 제공하는 경우만 허용됩니다.
- “MIT”
- MIT 라이선스 단독 사용을 나타냅니다.
- 특정 상황에서만 허용됩니다.
- “LGPL”
- GNU Lesser General Public License (LGPL)를 따릅니다.
- GPL과 유사하게 허용되며 제한 없이 사용 가능합니다.
- “Other”
- 커널이 알 수 없는 라이선스를 나타냅니다.
- 경고를 출력하며, 시스템 상태를 “tainted”로 설정합니다.
3. `MODULE_LICENSE` 지정 시의 주의사항
- 정확한 라이선스를 명시해야 커널과의 충돌을 피할 수 있습니다.
- “Proprietary” 또는 기타 비GPL 라이선스를 사용할 경우, 커널 디버깅 및 지원에 제한이 있을 수 있습니다.
4. 라이선스의 법적 의미
MODULE_LICENSE
값은 단순한 코드의 속성이 아닌 법적 책임을 반영합니다.
- 잘못된 라이선스를 명시하면 GPL 위반으로 간주될 수 있습니다.
- 라이선스를 명시하지 않는 경우 기본적으로 비GPL로 처리되며, 커널이 경고를 출력합니다.
5. 예제 코드
#include <linux/module.h>
#include <linux/kernel.h>
MODULE_LICENSE("GPL"); // GPL 라이선스 명시
MODULE_AUTHOR("Developer Name");
MODULE_DESCRIPTION("Kernel Module Example");
int init_module(void) {
printk(KERN_INFO "Example module loaded.\n");
return 0;
}
void cleanup_module(void) {
printk(KERN_INFO "Example module unloaded.\n");
}
커널 모듈의 MODULE_LICENSE
값은 법적, 기술적으로 중요한 정보로, 올바르게 지정해야 시스템의 안정성과 규정을 준수할 수 있습니다.
GPL과 비GPL 라이선스의 차이
Linux 커널 모듈 개발에서 GPL과 비GPL 라이선스는 모듈의 사용 범위와 커널과의 호환성에 중대한 영향을 미칩니다. 두 라이선스 유형의 차이를 이해하면 커널 개발에서의 법적 요구사항과 기술적 제한을 명확히 파악할 수 있습니다.
1. GPL 라이선스
GPL(General Public License)은 Linux 커널의 기본 라이선스로, 오픈소스 소프트웨어를 보호하고 소스 코드 공유를 촉진하는 데 중점을 둡니다.
- 특징
- 소스 코드를 공개해야 함.
- 파생 작업(모듈)이 GPL 또는 GPL 호환 라이선스를 따라야 함.
- 커널의 모든 기능과 API에 제한 없이 접근 가능.
- 장점
- 커널과 완벽히 호환되며 모듈 로드 시 경고 메시지나 제한이 없음.
- 오픈소스 커뮤니티의 기술적 지원을 받을 가능성이 높음.
- 예제
MODULE_LICENSE("GPL");
2. 비GPL 라이선스
비GPL 라이선스는 상용 소프트웨어나 독점 소프트웨어에 주로 사용되며, 소스 코드 공개와 공유 의무가 없습니다.
- 특징
- 소스 코드 비공개 가능.
- GPL의 “파생 작업 공유” 요구를 따르지 않음.
- 특정 커널 API에 대한 접근 제한이 있을 수 있음.
- 단점
- 커널 로드 시 시스템이 “tainted(오염됨)” 상태로 표시됨.
- 기술 지원이나 커널 업그레이드 시 문제가 발생할 가능성이 있음.
- 예제
MODULE_LICENSE("Proprietary");
3. 주요 차이점 비교
특징 | GPL | 비GPL |
---|---|---|
소스 코드 공개 여부 | 필수 | 선택 |
커널 API 접근 제한 | 없음 | 일부 제한 있음 |
커널 로드 시 경고 메시지 | 없음 | “tainted” 상태 표시 |
법적 요구사항 | 파생 작업도 GPL 호환 라이선스 필요 | 별도의 요구사항 없음 |
커뮤니티 지원 | 활발 | 제한적 |
4. 커널 모듈 개발 시 고려사항
- GPL을 사용하는 경우
커널의 모든 기능을 활용할 수 있으며, 오픈소스 생태계의 일원이 될 수 있습니다. - 비GPL을 사용하는 경우
독점 기술을 보호할 수 있으나, 커널과의 제한적 호환성을 감수해야 합니다.
5. 선택의 기준
- 오픈소스 커뮤니티와 협업하거나 커널 기능을 최대한 활용하려면 GPL을 선택하는 것이 적합합니다.
- 비GPL 라이선스는 독점 기술 보호와 상용화를 우선시하는 경우에 적합합니다.
GPL과 비GPL의 차이를 이해하고 적절한 라이선스를 선택하면, 법적 요구사항을 준수하면서 커널 모듈 개발을 효과적으로 진행할 수 있습니다.
비GPL 모듈의 제약 사항
Linux 커널은 GPL 라이선스를 따르며, 비GPL 라이선스를 사용하는 모듈에 대해 몇 가지 제약을 가합니다. 이는 커널과의 호환성뿐만 아니라 법적, 기술적 문제를 방지하기 위함입니다.
1. 커널의 “tainted” 상태
비GPL 모듈을 로드하면 커널은 “tainted(오염됨)” 상태로 표시됩니다.
- 의미: 커널에 비GPL 코드가 로드되었음을 나타냄.
- 영향:
- 시스템 디버깅 시 제한이 발생하며, 커널 개발자는 tainted 상태의 커널에 대한 지원을 거부할 수 있음.
- 디버깅 메시지에서 비GPL 모듈로 인해 발생한 문제를 식별하기 어려움.
- dmesg 출력 예시:
[Kernel Warning] Tainted: Proprietary module loaded.
2. 특정 커널 API 접근 제한
GPL 라이선스 전용 API(Exported GPL Symbols)에 대한 접근이 제한됩니다.
- 제한 이유: GPL 코드와 비GPL 코드 간의 혼합 사용을 방지하기 위함.
- 결과:
EXPORT_SYMBOL_GPL
로 선언된 함수는 비GPL 모듈에서 호출할 수 없음.- 일부 핵심 커널 기능을 사용할 수 없어 기능 구현에 제약이 생김.
3. 라이선스 적합성 문제
비GPL 모듈이 커널과 함께 배포될 경우, GPL 라이선스 위반으로 간주될 가능성이 있음.
- 위험 요소:
- GPL 라이선스는 파생 작업에 대해 동일한 라이선스(GPL)를 요구함.
- 비GPL 모듈이 커널과 강하게 결합되면, 법적 분쟁의 소지가 있음.
4. 유지보수 및 커뮤니티 지원 부족
- 비GPL 모듈은 오픈소스 커뮤니티에서의 지원을 기대하기 어렵습니다.
- 커널 업데이트 시 비GPL 모듈의 호환성 문제를 개발자가 직접 해결해야 함.
5. 상용 소프트웨어와의 혼합 사용
비GPL 모듈은 상용 소프트웨어와 함께 사용될 수 있지만, 다음과 같은 점을 유의해야 합니다.
- 장점: 독점 기술 보호 및 상용화 용이.
- 단점: 기술 지원 제한과 커널 업데이트 호환성 문제.
6. 실제 예시
비GPL 라이선스를 가진 모듈이 커널 API를 호출하려 할 때, 제한된 API로 인해 다음과 같은 오류가 발생할 수 있습니다.
// 접근 가능한 API 예시
EXPORT_SYMBOL(non_gpl_function); // 모든 모듈에서 접근 가능
// 접근 불가능한 API 예시
EXPORT_SYMBOL_GPL(gpl_only_function); // 비GPL 모듈에서는 호출 불가
7. 해결 방법
비GPL 모듈의 제약 사항을 극복하려면 다음과 같은 전략을 사용할 수 있습니다.
- 오픈소스 라이선스로 전환: 모듈을 GPL 호환 라이선스로 재작성.
- 독립형 모듈 설계: 커널 의존성을 최소화하고 독립적으로 작동하도록 설계.
- 상용 커널 패치 사용: 일부 상용 커널에서는 비GPL 모듈 지원을 확장하기도 함.
8. 요약
비GPL 라이선스를 사용하는 커널 모듈은 기술적, 법적, 유지보수 측면에서 제약을 받습니다. 이를 극복하려면 GPL 호환성을 고려하거나 독립적인 모듈 설계를 통해 문제를 최소화해야 합니다.
의존성 관리 실전 예제
Linux 커널 모듈 개발에서 의존성을 효과적으로 관리하는 것은 안정적인 시스템 작동을 보장하는 핵심 요소입니다. 다음은 의존성을 관리하는 실전 예제를 통해 구체적인 구현 방안을 소개합니다.
1. 모듈 의존성을 확인하는 `modinfo` 사용
modinfo
명령어를 사용해 특정 모듈의 의존성을 확인할 수 있습니다.
modinfo my_module.ko
출력 예:
filename: /lib/modules/<kernel-version>/my_module.ko
depends: dependent_module1,dependent_module2
depends
필드는 모듈이 의존하는 다른 모듈을 나열합니다.
2. `MODULE_DEPENDS` 매크로를 통한 의존성 명시
모듈 내부에서 의존성을 명확히 선언할 수 있습니다.
#include <linux/module.h>
#include <linux/kernel.h>
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Developer Name");
MODULE_DESCRIPTION("Example module with dependencies");
MODULE_DEPENDS("module1,module2"); // 의존 모듈 명시
int init_module(void) {
printk(KERN_INFO "Module with dependencies loaded.\n");
return 0;
}
void cleanup_module(void) {
printk(KERN_INFO "Module with dependencies unloaded.\n");
}
3. `modprobe`를 사용한 자동 의존성 로드
modprobe
명령어는 모듈 의존성을 자동으로 해결하며 필요한 모듈을 순서대로 로드합니다.
modprobe my_module
이는 depmod
에 의해 생성된 modules.dep
파일을 참고하여 의존성을 처리합니다.
4. `depmod`로 의존성 파일 업데이트
새로운 모듈을 추가하거나 의존성을 수정한 후 depmod
명령을 실행하여 의존성 정보를 갱신합니다.
depmod -a
갱신된 의존성은 /lib/modules/<kernel-version>/modules.dep
에 저장됩니다.
5. Makefile을 사용한 의존성 관리
Makefile을 활용해 빌드 단계에서 의존성을 정의할 수 있습니다.
obj-m += my_module.o
my_module-objs := dependent1.o dependent2.o
이 설정은 my_module
이 dependent1.c
와 dependent2.c
에 의존한다는 것을 의미합니다.
6. 실전 코드 예제
다음은 간단한 커널 모듈 의존성 관리 코드입니다.
모듈 1: 의존 모듈
#include <linux/module.h>
#include <linux/kernel.h>
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Dependency Author");
MODULE_DESCRIPTION("Dependency Module");
int init_module(void) {
printk(KERN_INFO "Dependency module loaded.\n");
return 0;
}
void cleanup_module(void) {
printk(KERN_INFO "Dependency module unloaded.\n");
}
모듈 2: 의존성을 가진 모듈
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Main Author");
MODULE_DESCRIPTION("Main Module with Dependency");
MODULE_DEPENDS("dependency_module");
int init_module(void) {
printk(KERN_INFO "Main module loaded with dependency.\n");
return 0;
}
void cleanup_module(void) {
printk(KERN_INFO "Main module unloaded.\n");
}
7. 디버깅 팁
- 의존 모듈이 로드되지 않은 경우,
dmesg
를 확인하여 로드 실패 원인을 진단합니다. insmod
대신modprobe
를 사용하는 것이 의존성 관리에 유리합니다.
8. 결론
Linux 커널 모듈에서 의존성을 명확히 관리하면 시스템 안정성을 유지할 수 있습니다. modinfo
, modprobe
, depmod
와 같은 도구와 Makefile을 활용해 효율적인 의존성 관리를 구현하십시오.
MODULE_LICENSE와 법적 준수
Linux 커널 모듈 개발에서 MODULE_LICENSE
는 단순한 기술적 요소를 넘어 법적 요구사항을 준수하기 위한 중요한 구성 요소입니다. 모듈이 커널 라이선스 정책과 호환되는지 명시함으로써, 법적 분쟁을 예방하고 커널과의 호환성을 보장합니다.
1. `MODULE_LICENSE`의 법적 의미
MODULE_LICENSE
는 모듈의 라이선스 정보를 커널에 전달하며, 다음과 같은 법적 역할을 수행합니다.
- GPL 준수 확인: 커널은 모듈의 라이선스가 GPL 또는 GPL 호환 라이선스인지 확인합니다.
- 소스 코드 공개 의무: GPL을 사용하는 경우, 모듈의 소스 코드를 사용자에게 제공해야 합니다.
- 저작권 보호: 모듈이 커널 API와 상호작용하는 방식을 정의하여 저작권을 준수합니다.
2. 비GPL 모듈의 법적 위험
비GPL 라이선스를 사용하는 모듈은 다음과 같은 법적 문제를 초래할 수 있습니다.
- GPL 위반:
- 커널은 GPL 라이선스를 따르며, 비GPL 모듈이 커널 내부 API와 밀접하게 작동하면 파생 작업으로 간주될 수 있습니다.
- 이는 GPL의 요구사항을 위반하는 행위로 법적 분쟁으로 이어질 가능성이 있습니다.
- 소스 코드 요구:
- 비GPL 모듈이 커널과 강하게 결합되어 있다면, 해당 모듈의 소스 코드 제공이 요구될 수 있습니다.
3. 라이선스 지정의 중요성
MODULE_LICENSE
를 정확히 지정하지 않으면, 커널은 모듈을 비GPL로 간주하며 시스템 상태를 “tainted(오염됨)”로 표시합니다.
- 경고 출력:
[Kernel Warning] Kernel tainted: Non-GPL module loaded.
- 법적 문제 방지: 명확한 라이선스 선언을 통해 라이선스 분쟁을 사전에 차단할 수 있습니다.
4. 주요 법적 사례
- GPL 위반 사례:
일부 회사가 소스 코드를 공개하지 않은 커널 모듈을 배포하여 GPL 위반으로 고소당한 사례가 있습니다. - 해결 방법: 소스 코드 공개 또는 모듈을 독립적인 사용자 공간 프로그램으로 재작성.
- 라이선스 모호성 문제:
MODULE_LICENSE
를 명시하지 않아 모듈의 라이선스 상태가 불명확해진 경우, 모듈 로드 및 지원 과정에서 문제가 발생했습니다.
5. 권장 사항
- GPL 또는 GPL 호환 라이선스 사용:
- 커널과의 호환성을 보장하고 법적 문제를 방지합니다.
- 라이선스 정보 명확히 명시:
MODULE_LICENSE
매크로를 항상 사용하여 모듈의 라이선스를 명시적으로 선언합니다.
- 법적 검토 수행:
- 모듈 배포 전에 법적 전문가를 통해 라이선스 적합성을 검토합니다.
6. 예제 코드
GPL 라이선스를 따르는 올바른 MODULE_LICENSE
사용 예제:
#include <linux/module.h>
#include <linux/kernel.h>
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Developer Name");
MODULE_DESCRIPTION("Legal Compliance Example Module");
int init_module(void) {
printk(KERN_INFO "Legal compliance module loaded.\n");
return 0;
}
void cleanup_module(void) {
printk(KERN_INFO "Legal compliance module unloaded.\n");
}
7. 결론
MODULE_LICENSE
는 기술적 요소일 뿐만 아니라 법적 준수의 핵심입니다. 모듈 개발자는 항상 적절한 라이선스를 지정하고, GPL 라이선스 정책을 철저히 준수하여 법적 분쟁을 방지하고 커널과의 호환성을 보장해야 합니다.
요약
Linux 커널 모듈에서 MODULE_LICENSE
와 의존성 관리는 기술적 안정성과 법적 준수의 핵심 요소입니다. MODULE_LICENSE
는 모듈의 라이선스를 명시하여 커널과의 호환성을 보장하고, 의존성 관리를 통해 모듈 로드와 시스템 안정성을 유지할 수 있습니다. GPL 라이선스를 준수하면 커널의 모든 기능을 활용할 수 있으며, 법적 문제를 예방할 수 있습니다. 올바른 의존성 관리와 라이선스 선언은 효율적이고 신뢰할 수 있는 커널 모듈 개발의 기반이 됩니다.