디시인사이드 갤러리

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

갤러리 본문 영역

dav1d vs. rav1d: 오픈 소스 코덱 논란의 이면과 '메모리 안

루비갤로그로 이동합니다. 2025.07.03 11:09:51
조회 37 추천 0 댓글 0

dav1d vs. rav1d: 오픈 소스 코덱 논란의 이면과 '메모리 안전성'의 진실

최근 Hacker News를 뜨겁게 달궜던 dav1drav1d (Rust 포트) 비디오 디코더 성능 및 안전성 논란에 대해 자세히 알아보겠습니다. 단순한 기술 논쟁을 넘어선 감정적, 윤리적 쟁점들, 그리고 '메모리 안전성'이라는 화두의 복잡한 이면을 짚어봅니다.


논란의 시작: rav1d의 성능 개선과 FFmpeg의 불만

rav1d 프로젝트는 기존 dav1d (C 언어 기반) 디코더를 Rust로 포팅하여 성능을 개선하고 메모리 안전성을 높이는 것을 목표로 했습니다. 초기 벤치마크에서 rav1ddav1d보다 약간 느리지만 'Rust로도 충분히 빠르다'는 인식을 심어주며 긍정적인 평가를 받았습니다. 심지어 memorysafety.org에서는 rav1d의 성능 향상을 위한 현상금까지 걸었습니다.

하지만 이 과정에서 FFmpeg 프로젝트(VLC 미디어 플레이어의 기반 기술 중 하나이자 dav1d와도 밀접한 관계)의 트위터 계정에서 강한 비난이 터져 나왔습니다. FFmpeg 측은 rav1d가 '기생 프로젝트'에 불과하며, 자신들의 노력을 가로채고 있다고 주장했습니다. 이 트윗은 공격적이고 빈정거리는 어조로 인해 오히려 트위터 사용자들로부터 FFmpeg이 '유독하다'거나 '징징댄다'는 역풍을 맞기도 했습니다.


"기생 논란": rav1d는 정말 숙주를 건드렸을까?

FFmpeg 측의 주장은 rav1ddav1d의 핵심 최적화 코드, 특히 **수십 년간 쌓아 올린 dav1d의 어셈블리 코드**를 Rust의 unsafe 블록을 통해 '그대로' 가져다 썼다는 데서 출발합니다.

FFmpeg 개발자들의 입장은 다음과 같습니다:

  • "우리는 이 어셈블리 코드를 만들기 위해 피땀 흘려 고도로 최적화하고 수많은 버그를 잡았다."

  • "rav1d는 그 힘든 과정을 건너뛰고 우리 코드를 재활용하면서, 마치 Rust 언어 자체의 우수성 덕분에 성능이 좋은 것처럼 홍보하고 있다."

  • "심지어 우리 프로젝트는 만성적인 자금과 인력 부족에 시달리는데, '새로운' Rust 프로젝트에 자원이 몰리는 것은 불합리하다."

FFmpeg 측은 이러한 상황을 마치 dav1d가 일하고 rav1d가 성과를 가로채는 '기생적' 관계로 묘사했습니다. 만약 dav1d가 유지보수되지 않아 망하게 되면, 그 코드에 의존하는 rav1d 또한 영향을 받을 수 있다는 지적은 이러한 우려를 반영합니다.


'지적 정직성' 논란과 '메모리 안전성'의 복잡한 진실

논란은 여기서 그치지 않습니다. rav1d의 핵심 강점은 Rust가 제공하는 **'메모리 안전성'**인데, FFmpeg 측은 이 주장에 대해서도 의문을 제기합니다.

  • 어셈블리 코드의 위험성: FFmpeg 측은 어셈블리 코드가 C보다 훨씬 더 저수준으로 메모리를 직접 조작하므로, 가장 잠재적인 위험성이 큰 코드라고 지적합니다. Rust의 unsafe 블록은 이 어셈블리 코드의 메모리 안전성을 컴파일러가 검증하지 않는다는 의미이므로, 결국 가장 위험한 부분은 Rust의 안전성 모델 밖에 남아있다는 것입니다.

  • 홍보와 현실의 간극: rav1d 개발자들은 Rust 전문가이므로 unsafe의 의미와 어셈블리 코드의 위험성을 인지하고 있었을 겁니다. 그럼에도 불구하고 프로젝트를 "메모리 안전한 Rust"로 강조하면서 unsafe 영역의 존재와 그 한계가 충분히 명확하게 전달되지 않았다는 비판이 제기됩니다. 이는 FFmpeg 측에서 볼 때 '지적 정직성'의 문제로 비춰질 수 있습니다.

Rust 개발자들은 C 코드 부분을 Rust로 전환함으로써 전반적인 코드베이스의 견고성을 높이고 새로운 버그 유입을 막을 수 있다는 현실적인 절충을 택했을 수 있습니다. 하지만 대중에게 "Rust로 포팅했다 = 안전해졌다"는 단순한 공식으로 전달될 수 있다는 점이 문제입니다.


FFmpeg의 딜레마: 왜 숙주가 불평해야 했나?

FFmpeg이 아무리 상세한 사실을 공개했더라도 대중의 역풍을 피하기 어려웠을 것이라는 지적도 있습니다. 사용자들은 보통 다음과 같은 경향을 보입니다.

  • '무관심의 편향': 대부분의 사용자는 제품/서비스의 이면에 있는 복잡성이나 개발자의 고충에 대해 근본적인 무관심을 가집니다. '더 안전하고 빠르다'는 단순하고 명쾌한 메시지를 선호하며, 그 혜택을 위한 개발자의 노고나 재정적 어려움에는 관심이 없습니다.

  • '불평'으로 인식: FFmpeg의 주장이 아무리 정교해도, 그 기저에 '우리는 힘들고, 너희가 우리 노력을 인정 안 해준다'는 억울함이 깔려 있다면, 이는 청중에게 단순히 '불평'으로 들릴 수 있습니다.

이 논란은 기술적 우월성을 넘어 인간적인 존중, 노력의 인정, 그리고 오픈 소스 생태계 내에서의 건강한 소통 방식에 대한 근본적인 질문을 던집니다. rav1d는 '안전성'이라는 새로운 가치를 제시하며 혁신을 시도했지만, 그 과정에서 기존 프로젝트 개발자들의 노고와 감정에 대한 충분한 공감과 배려가 부족했다는 비판에 직면했습니다.


이번 논란을 통해 우리는 기술의 발전과 함께 공동체 내의 미묘한 관계, 그리고 진실을 효과적으로 소통하는 방법에 대한 깊은 고민이 필요하다는 것을 다시금 깨닫게 됩니다.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 현역으로 군대 안 간게 의아한 스타는? 운영자 25/06/30 - -
AD 휴대폰 바꿀까? 특가 구매 찬스! 운영자 25/07/02 - -
2869424 그러니까 무조건 러스트만을 찬양/옹호할게 아니라 루비갤로그로 이동합니다. 07.03 36 1
2869423 ❤✨☀⭐나님 시작합니당⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 07.03 30 0
2869422 부록 B: 동일 안전성 목표 하의 코드 비교 - Rust vs. Ada/ [2] 루비갤로그로 이동합니다. 07.03 44 0
2869420 러스트 빠 주장 분석: C언어도 stdio를 못 쓰는가? 루비갤로그로 이동합니다. 07.03 47 2
2869418 c++ 집에있는 책 펴봤느데 c++11기반 이네 [2] 프갤러(114.205) 07.03 63 0
2869417 새끼길냥덩 주울깡? ♥냥덩이♥갤로그로 이동합니다. 07.03 43 0
2869416 CPP 배울거면 그나마 스콧 메이어 책 이펙티브 모던C++봐야하는데 [22] ㅆㅇㅆ(124.216) 07.03 92 1
2869415 c는 임베디드에서 stdio쓸 수 있는줄 아나봄 프갤러(42.22) 07.03 49 0
2869414 백악관이 rust ada 등 메모리안전 언어를 추천하는 가운데 kyle이 [1] 발명도둑잡기(118.216) 07.03 50 0
2869413 c와 런타임라니브러리 합친 크기와 동일 기능하는 러스트 프로그램 실행파일 발명도둑잡기(118.216) 07.03 34 0
2869412 임베디드 시스템 및 리눅스 커널 적용의 실제적 제약 (바이너리, ABI 루비갤로그로 이동합니다. 07.03 56 0
2869411 내일 내가 만든 임베디드 시연하러 가야함 [1] 프갤러(211.234) 07.03 54 0
2869410 CPP는 책으로 배우면 잘못 입문한다. [6] ㅆㅇㅆ(124.216) 07.03 95 1
2869409 임베디드에서 동적링킹 쓰나 [6] 발명도둑잡기(118.216) 07.03 77 0
2869408 부록 A: ‘합리적 비판’에 대한 ‘비이성적 반응’ 사례 연구 루비갤로그로 이동합니다. 07.03 40 0
2869407 안되겠다. 자짤을 톡시한 크랩랭으로 복귀해야겠다. 프갤러(42.27) 07.03 32 0
2869406 나님 왤케 특별하실깡? ♥냥덩이♥갤로그로 이동합니다. 07.03 32 0
2869405 동적 링크는 시스템에 미리 그 라이브러리가 통째로 설치되어 있어야돼 프갤러(42.27) 07.03 43 0
2869404 행님들 C++입문할라는데 입문서 + 코딩문제집 동시에 보는거어 [2] 프갤러(123.142) 07.03 43 0
2869403 러빠하는 얘기보면 '동정 링킹'의 개념을 아예 모르는거 같음. ㅎㅎ 루비갤로그로 이동합니다. 07.03 46 0
2869402 전공자 LG 유플러스 부트캠프 어떨까요?? [3] 프갤러(218.50) 07.03 167 0
2869401 보석아. 너는 지금 동적 링크가 어떻게 동작하는지도 모르고 있는거야. [1] 프갤러(27.177) 07.03 66 0
2869400 내가 llm 조련하는거 보고가~~[위 러빠 얘기도 넣어 업뎃함] 루비갤로그로 이동합니다. 07.03 36 1
2869399 그 보석새끼 또 임베디드 바이너리 크기 타령하네 ㅋㅋ 프갤러(223.33) 07.03 38 0
2869398 냥덩너무조와? [2] ♥냥덩이♥갤로그로 이동합니다. 07.03 50 0
2869397 네이버 카페가 안들어가짐 프갤을 잘 되는데, 넥도리아(121.139) 07.03 31 0
2869396 ㅆㅇㅆ아 그건 너 말이 맞다. [2] 루비갤로그로 이동합니다. 07.03 77 1
2869395 지금 netstat, tasklist 결과 [2] 발명도둑잡기(118.216) 07.03 61 0
2869394 커뮤니티 사이트 회원가입 빡세게 해놓는 이유...txt ㅇㅇ갤로그로 이동합니다. 07.03 54 0
2869393 나는 근데 루비보면서 LLM의 무서운점을 느낌. [4] ㅆㅇㅆ(124.216) 07.03 70 2
2869392 ㅆㅇㅆ 고맙다. 어제 마니 까줘서 보강했어 [2] 루비갤로그로 이동합니다. 07.03 76 1
2869391 애들아 메모리쪽 공부해 [6] 프갤러(106.101) 07.03 121 1
2869390 갤에 러까 글 진지하게 읽는 사람 있음? [2] 프갤러(218.154) 07.03 53 0
2869389 추억의 만찐두빵⭐+ ♥냥덩이♥갤로그로 이동합니다. 07.03 33 0
2869388 러스트 혹세무민 = 곡학아세 + 오만 + 기만 루비갤로그로 이동합니다. 07.03 28 1
2869387 에필로그: 러스트 신화는 막을 내린다 루비갤로그로 이동합니다. 07.03 33 0
2869386 지금까지 나 신고한 새끼들 나중에 싸그리 신고해서 추적한다 [1] 발명도둑잡기(118.216) 07.03 42 0
2869385 배달의민족 배달료 중앙값 표시 항의 발명도둑잡기(39.7) 07.03 49 0
2869384 제5장: 러스트의 설계, 혁신인가 결함인가? 루비갤로그로 이동합니다. 07.03 64 0
2869383 ❤✨☀⭐나님 시작합니당⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 07.03 24 0
2869382 1400줄 추가 1000줄 삭제하고 돌렸는데 ←Backspace갤로그로 이동합니다. 07.03 47 0
2869381 가끔 코딩이 뭘까 싶기도하다. 코딩이라는 무형적 지식은 [6] ㅆㅇㅆ(124.216) 07.03 76 0
2869380 그러므로 오늘은 유니티 공부입니다 [3] 루도그담당(211.184) 07.03 69 0
2869379 CLR이나 JVM [16] 루도그담당(211.184) 07.03 137 0
2869376 근데 언어 몇개가 중요한가 그냥 뭘 개발하는지가 중요하지 [19] ㅆㅇㅆ(124.216) 07.03 122 0
2869375 이병신은 C/C++ 개발자한테 하는언어가 몇개냐하네 [45] ㅇㅇ(223.38) 07.03 126 1
2869374 가진것도, 아는것도 없는 인생에 두려울게 있겠습니까?? [2] ㅇㅇ(223.38) 07.03 65 0
2869373 상사가 맥북사비로 사줌 [13] 프갤러(106.101) 07.03 100 0
2869371 일본기업의 '능력주의'가 역겨운 이유 [2] 프로외노자갤로그로 이동합니다. 07.03 80 0
2869370 일본기업의 '스페셜리스트' 제도의 한계 프로외노자갤로그로 이동합니다. 07.03 49 0
뉴스 정동원, ‘걍남자’서 임영웅과 1박 2일 캠핑 여행 "찐형제 케미" 디시트렌드 07.04
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2