Microsoft MVP성태의 닷넷 이야기
Linux: 84. WSL / Ubuntu 20.04 - bpftool 설치 [링크 복사], [링크+제목 복사],
조회: 8413
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

(시리즈 글이 2개 있습니다.)
Linux: 83. WSL / Ubuntu 22.04 - bpftool 설치
; https://www.sysnet.pe.kr/2/0/13762

Linux: 84. WSL / Ubuntu 20.04 - bpftool 설치
; https://www.sysnet.pe.kr/2/0/13763




WSL / Ubuntu 20.04 - bpftool 설치

지난 글에서는 22.04에서 bpftool을 설치해 봤는데요,

WSL / Ubuntu 22.04 - bpftool 설치
; https://www.sysnet.pe.kr/2/0/13762

이상하게도 Ubuntu 20.04에서는 빌드 시 (libelf.h 오류 외에도) llvm-strip 오류가 발생합니다.

make: llvm-strip: Command not found
make: *** [Makefile:211: profiler.bpf.o] Error 127
make: *** Deleting file 'profiler.bpf.o'

어쨌든 "sudo apt-get install llvm -y" 설치하면 되지만, 그래도 해결이 안 되는 오류가 발생합니다.

  CLANG    pid_iter.bpf.o
skeleton/pid_iter.bpf.c:106:6: error: use of unknown builtin '__builtin_preserve_enum_value' [-Wimplicit-function-declaration]
            bpf_core_enum_value_exists(enum bpf_link_type___local,
            ^
/home/kevin/temp/bpftool/src/bootstrap/libbpf/include/bpf/bpf_core_read.h:273:2: note: expanded from macro 'bpf_core_enum_value_exists'
        __builtin_preserve_enum_value(*(typeof(enum_type) *)enum_value, BPF_ENUMVAL_EXISTS)
        ^
1 error generated.
make: *** [Makefile:210: pid_iter.bpf.o] Error 1

찾아봐도 딱히 답이 없는데요, 컴파일 오류가 발생하는 헤더 파일을 보니,

$ cat -n /home/kevin/temp/bpftool/src/bootstrap/libbpf/include/bpf/bpf_core_read.h
...[생략]...

271  #ifdef __clang__
272  #define bpf_core_enum_value_exists(enum_type, enum_value)                   \
273          __builtin_preserve_enum_value(*(typeof(enum_type) *)enum_value, BPF_ENUMVAL_EXISTS)
274  #else
275  #define bpf_core_enum_value_exists(enum_type, enum_value)                   \
276          __builtin_preserve_enum_value(___bpf_typeof(enum_type), enum_value, BPF_ENUMVAL_EXISTS)
277  #endif

clang이 설치된 경우에만 컴파일을 타는 코드에서 오류가 발생한 것입니다. 예상할 수 있겠지만, clang을 삭제했더니 정상적으로 빌드가 됩니다. ^^

$ sudo apt remove clang -y




Ubuntu 20.04에 설치되는 기본 clang 버전이 10.0인데요, 저런 과정 없이 설치가 잘 된 22.04의 경우에는 14.0이었습니다.

$ clang --version
clang version 10.0.0-4ubuntu1
Target: x86_64-pc-linux-gnu
Thread model: posix
InstalledDir: /usr/bin

혹시나 clang의 버전 문제가 아닐까 싶어서 clang을 최신 버전(18)으로 업그레이드했더니 ^^ 정상적으로 빌드가 됩니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 10/12/2024]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 136  137  138  139  140  141  [142]  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1596정성태1/17/201426514오류 유형: 214. Local SYSTEM 계정으로 실행된 IE에서 다운로드가 안 되는 문제
1595정성태1/16/201424304오류 유형: 213. attrib - Not resetting system file
1594정성태1/15/201426533오류 유형: 212. 마이크로소프트 라이브 계정 로그인 실패하는 경우
1593정성태1/14/201424955오류 유형: 211. ASP.NET 응용 프로그램을 IIS Express에서 디버깅할 때 "Requested registry access is not allowed" 오류 발생
1592정성태1/14/201424212오류 유형: 210. 2대의 AD가 있는 경우 도메인에 컴퓨터 추가를 실패한다면? [1]
1591정성태1/14/201427217오류 유형: 209. DebugDiag: Unable to find mscordacwks_x86_x86_[...version...].dll
1590정성태1/14/201428579오류 유형: 208. VSS Writer - NTDS 오류
1589정성태1/14/201437658Windows: 85. 컴퓨터를 껐는데도 어느 순간 자동으로 켜진다면? [2]
1588정성태1/14/201434076Windows: 84. 윈도우 7/8 - 메뉴 항목이 잔상으로 남는 문제
1587정성태1/14/201430193디버깅 기술: 60. NT 서비스가 시작하자마자 디버거를 연결시키는 방법 (2)
1586정성태1/14/201431683디버깅 기술: 59. NT 서비스가 시작하자마자 디버거를 연결시키는 방법 (1) [1]
1585정성태1/14/201434489VS.NET IDE: 84. Visual Studio를 이용한 파일 비교(diff)
1584정성태1/13/201436216Windows: 83. 윈도우 8 - UI가 있는 프로그램을 Local SYSTEM 권한의 세션 0 데스크톱에서 실행하는 방법
1583정성태1/13/201434741Windows: 82. 윈도우 8 - "Interactive Services Detection" 서비스 시작하는 방법 [1]
1582정성태1/12/201433139개발 환경 구성: 210. 원격 데스크톱(RDP) 접속 프로그램 - Royal TS [1]
1581정성태1/12/201434482.NET Framework: 408. 자바와 닷넷의 제네릭 차이점 - 중간 언어 및 공변/반공변 처리 [8]
1580정성태1/12/201444942.NET Framework: 407. 닷넷 사용자 정의 예외 클래스의 최소 구현 코드 [1]
1579정성태1/12/201426053오류 유형: 207. System.ArgumentException was unhandled - Message=[net_WebHeaderInvalidControlChars]
1578정성태1/11/201438393개발 환경 구성: 209. Fiddler에서 WebSocket 통신을 모니터링하는 방법 [1]
1577정성태1/11/201430178오류 유형: 206. WriteFile Win32API 사용 시 비정상 종료 현상 [4]
1576정성태1/11/201445902Windows: 81. 긴 이름의 파일/폴더 삭제하는 법 [5]
1575정성태1/11/201425439오류 유형: 205. Exception calling "Provision" with "0" argument(s): "The timer job did not complete running within the allotted time."
1574정성태1/11/201428094오류 유형: 204. An unhandled exception ('System.Security.Cryptography.CryptographicException') occurred in OWSTIMER.EXE
1573정성태1/11/201426348오류 유형: 203. 이벤트 로그 에러 - MsiInstaller에서 Chart Controls 설치 관련 오류 발생
1572정성태1/9/201430002.NET Framework: 406. CoreLab - OraDirect .NET 사용법
1571정성태1/9/201425878.NET Framework: 405. override 메서드가 정의된 타입의 인스턴스로 base 메서드를 호출하는 방법 - 두 번째 이야기
... 136  137  138  139  140  141  [142]  143  144  145  146  147  148  149  150  ...