디시인사이드 갤러리

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

갤러리 본문 영역

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

루비갤로그로 이동합니다. 2025.07.03 11:09:51
조회 33 추천 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 - -
2869467 소형 피씨스피커는 페블 v2, v3가 좋다 발명도둑잡기(118.216) 07.03 23 0
2869465 acm 인강 들으려고했는데 여기 로그인 필수네 프갤러(106.102) 07.03 22 0
2869464 ai가 뱉는 말이면 검증도 안하고 물고 빨면서 대학원 ㅇㅈㄹ ㅋㅋㅋ 프갤러(110.8) 07.03 32 0
2869463 도둑맞은 내 일기 관련해서 연쇄살인이 난 것 같은데 영화 <커미션> 발명도둑잡기(118.216) 07.03 48 0
2869462 둘 중 하나지. 러스트 못배우는 열등감에 그냥 정신승리이거나 프갤러(110.8) 07.03 38 0
2869461 러까의 저능함이 증명되는 순간이구나 프갤러(110.8) 07.03 38 0
2869459 인강좀 질문좀 프갤러(106.102) 07.03 22 0
2869456 프로외노자 등 일본 거주 프갤러분들 지진 대비 어떻게 하십니까 [1] 발명도둑잡기(118.216) 07.03 44 0
2869455 나경원 기체조하는 사람같지않냐? 헬마스터갤로그로 이동합니다. 07.03 55 0
2869454 ❤✨☀⭐나님 시작합니당⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 07.03 33 0
2869452 난 과집중이 항상 문제임에오 [2] 조루디(110.35) 07.03 54 0
2869451 시간이 빠르다에요 조루디(110.35) 07.03 28 0
2869449 요즘은 정신과약 먹고있음 [7] 조루디(110.35) 07.03 79 2
2869448 딱국 잘사냐 조루디(110.35) 07.03 47 3
2869447 "집값 안정시켜야 한다, 어떻게 세운 이재명 정부인데..." 발명도둑잡기(118.216) 07.03 56 0
2869446 하 그놈의 대용량 조루디(110.35) 07.03 39 0
2869445 나 2년차 실화냐 [2] 조루디(110.35) 07.03 52 0
2869444 오히려 자바충들이 싸지른 똥라이브러리들을 보면 러스트는 축복이다. 프갤러(27.172) 07.03 47 0
2869443 와일드샤크 패킷/C++ 혹은 C# 잘아시는교수님있으실까요? 프갤러(183.107) 07.03 40 0
2869442 러스트 라이브러리가 부족한건 사실이다. 프갤러(27.172) 07.03 42 1
2869438 업뎃) 동일 안전성 목표 하의 코드 비교 - Rust vs. Ada/.. 루비갤로그로 이동합니다. 07.03 62 0
2869437 7 ㅇㅇ(106.101) 07.03 39 0
2869435 나님 리짜이밍 덕분에 집값 폭등즁 ㅎㅅㅎ ♥냥덩이♥갤로그로 이동합니다. 07.03 33 0
2869431 냉정하게 23살이면 아직 기회있다고 보는게 맞는 나이임?? [2] ㅇㅇ(223.38) 07.03 52 0
2869429 미국 스타일 여성분 마주쳤다 [1] 헬마스터갤로그로 이동합니다. 07.03 59 0
2869427 ㅁㅌ겠네.. 러빠들 파닥파닥 날뛰면서 개난리칠거 예상된다. 루비갤로그로 이동합니다. 07.03 39 0
2869424 그러니까 무조건 러스트만을 찬양/옹호할게 아니라 루비갤로그로 이동합니다. 07.03 32 1
2869423 ❤✨☀⭐나님 시작합니당⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 07.03 27 0
2869422 부록 B: 동일 안전성 목표 하의 코드 비교 - Rust vs. Ada/ [2] 루비갤로그로 이동합니다. 07.03 40 0
2869420 러스트 빠 주장 분석: C언어도 stdio를 못 쓰는가? 루비갤로그로 이동합니다. 07.03 45 2
2869418 c++ 집에있는 책 펴봤느데 c++11기반 이네 [2] 프갤러(114.205) 07.03 57 0
2869417 새끼길냥덩 주울깡? ♥냥덩이♥갤로그로 이동합니다. 07.03 40 0
2869416 CPP 배울거면 그나마 스콧 메이어 책 이펙티브 모던C++봐야하는데 [22] ㅆㅇㅆ(124.216) 07.03 89 1
2869415 c는 임베디드에서 stdio쓸 수 있는줄 아나봄 프갤러(42.22) 07.03 47 0
2869414 백악관이 rust ada 등 메모리안전 언어를 추천하는 가운데 kyle이 [1] 발명도둑잡기(118.216) 07.03 48 0
2869413 c와 런타임라니브러리 합친 크기와 동일 기능하는 러스트 프로그램 실행파일 발명도둑잡기(118.216) 07.03 33 0
2869412 임베디드 시스템 및 리눅스 커널 적용의 실제적 제약 (바이너리, ABI 루비갤로그로 이동합니다. 07.03 51 0
2869411 내일 내가 만든 임베디드 시연하러 가야함 [1] 프갤러(211.234) 07.03 52 0
2869410 CPP는 책으로 배우면 잘못 입문한다. [6] ㅆㅇㅆ(124.216) 07.03 93 1
2869409 임베디드에서 동적링킹 쓰나 [6] 발명도둑잡기(118.216) 07.03 73 0
2869408 부록 A: ‘합리적 비판’에 대한 ‘비이성적 반응’ 사례 연구 루비갤로그로 이동합니다. 07.03 36 0
2869407 안되겠다. 자짤을 톡시한 크랩랭으로 복귀해야겠다. 프갤러(42.27) 07.03 28 0
2869406 나님 왤케 특별하실깡? ♥냥덩이♥갤로그로 이동합니다. 07.03 29 0
2869405 동적 링크는 시스템에 미리 그 라이브러리가 통째로 설치되어 있어야돼 프갤러(42.27) 07.03 39 0
2869404 행님들 C++입문할라는데 입문서 + 코딩문제집 동시에 보는거어 [2] 프갤러(123.142) 07.03 37 0
2869403 러빠하는 얘기보면 '동정 링킹'의 개념을 아예 모르는거 같음. ㅎㅎ 루비갤로그로 이동합니다. 07.03 46 0
2869402 전공자 LG 유플러스 부트캠프 어떨까요?? [3] 프갤러(218.50) 07.03 138 0
2869401 보석아. 너는 지금 동적 링크가 어떻게 동작하는지도 모르고 있는거야. [1] 프갤러(27.177) 07.03 60 0
2869400 내가 llm 조련하는거 보고가~~[위 러빠 얘기도 넣어 업뎃함] 루비갤로그로 이동합니다. 07.03 33 1
2869399 그 보석새끼 또 임베디드 바이너리 크기 타령하네 ㅋㅋ 프갤러(223.33) 07.03 36 0
뉴스 걸스데이 민아, 배우 온주완과 11월 결혼 디시트렌드 07.04
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2