디시인사이드 갤러리

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

갤러리 본문 영역

rav1d 측은 메모리 안전성 불가능을 알고 있었을까?

루비갤로그로 이동합니다. 2025.07.03 11:10:53
조회 31 추천 0 댓글 0

rav1d 측은 메모리 안전성 불가능을 알고 있었을까?

rav1d 프로젝트가 dav1d의 수기로 작성된 어셈블리 코드를 unsafe 블록을 통해 가져다 쓴다는 점을 고려할 때, rav1d 개발자들이 Rust의 완전한 메모리 안전성을 모든 코드에 걸쳐 달성하는 것이 불가능하다는 사실을 인지하고 있었을 가능성이 매우 높습니다.

그 이유는 다음과 같습니다.

  1. Rust 언어의 이해도: rav1d 개발자들은 Rust 전문가이며, unsafe 키워드의 의미와 사용 목적을 누구보다 잘 알고 있습니다. Rust에서 unsafe 블록은 컴파일러가 메모리 안전성 보장을 중단하고 개발자에게 그 책임을 위임한다는 명확한 신호입니다. 이는 곧 해당 블록 내의 코드에서 메모리 안전성 문제가 발생할 수 있음을 의미합니다.

  2. 어셈블리 코드의 특성: 어셈블리 코드는 저수준 언어로, Rust의 소유권(ownership)이나 차용(borrowing) 규칙을 따르지 않습니다. C 코드에서 파생된 어셈블리 코드는 C의 메모리 관리 모델을 따르며, 이는 Rust의 엄격한 안전성 검사로는 검증될 수 없습니다. rav1d 개발자들이 이 사실을 몰랐을 리 없습니다.

  3. 프로젝트의 현실적 목표: rav1d 프로젝트의 목표는 dav1d를 처음부터 Rust로 다시 작성하는 '순수주의'적인 접근보다는, 기존의 잘 최적화된 어셈블리 코드를 활용하면서 C 코드 부분을 Rust로 전환하여 전반적인 코드베이스의 안전성을 높이는 것에 있었을 가능성이 큽니다. 즉, 100% 완전한 Rust 안전성을 달성하기보다는, unsafe 영역을 최소화하면서 최대한의 안전성 이점을 얻으려는 현실적인 절충을 택했을 겁니다.

왜 그런 선택을 했을까?

그럼에도 불구하고 이런 선택을 한 이유는 복합적입니다.

  • 효율성: dav1d의 어셈블리 코드를 처음부터 Rust로 다시 작성하는 것은 막대한 시간과 노력이 필요하며, 기존 성능을 따라잡는 것은 매우 어려운 일입니다. 잘 검증되고 최적화된 기존 코드를 재활용하는 것이 훨씬 효율적입니다.

  • 부분적 안전성 향상: 비록 어셈블리 부분은 unsafe 영역에 남아있더라도, dav1d의 상당 부분을 차지하는 C 코드를 Rust로 전환함으로써 새로운 버그 유입을 막고 전반적인 코드베이스의 견고성을 높일 수 있습니다. 이는 '전부 아니면 전무'의 문제가 아니라, '최대한 안전하게' 만들려는 시도입니다.

  • 언어의 홍보: Rust가 실제 사용 사례에서 C/C++ 프로젝트를 얼마나 효과적으로 대체할 수 있는지 보여주는 중요한 사례가 됩니다.

"지적 정직성" 논란의 재점화

문제는 이러한 현실적인 절충이 대중에게 전달되는 방식에서 '지적 정직성' 논란을 불러일으켰다는 점입니다.

  • rav1d와 관련된 홍보나 memorysafety.org의 현상금 소개 등에서 'Rust의 메모리 안전성'이라는 장점이 과도하게 부각되면서, unsafe 영역의 존재와 그 한계가 충분히 명확하게 전달되지 않았을 수 있습니다.

  • FFmpeg 측이 비판하는 지점은 바로 이 부분입니다. rav1d일부 위험한 부분을 그대로 유지하면서도 전체 프로젝트가 마치 Rust 덕분에 완벽히 안전한 것처럼 포장하려는 시도가 있었다고 느끼는 것이죠.

결국 rav1d 개발자들은 기술적인 한계를 분명히 알고 있었을 겁니다. 하지만 그들이 이 사실을 어떻게 대중과 기존 커뮤니티에 소통했는지는 또 다른 문제입니다. 이 간극이 FFmpeg 측의 강한 반발과 대중의 오해를 불러일으킨 주요 원인 중 하나라고 볼 수 있습니다.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 현역으로 군대 안 간게 의아한 스타는? 운영자 25/06/30 - -
AD 휴대폰 바꿀까? 특가 구매 찬스! 운영자 25/07/02 - -
공지 프로그래밍 갤러리 이용 안내 [88] 운영자 20.09.28 45148 65
2869570 청년기본소득 줄까? 넥도리아(175.196) 05:19 15 0
2869566 루비가 훌륭한건 알겠음 프갤러(118.37) 04:59 20 1
2869562 디시를 어떻게해야 닉만으로 부대를 알지? [9] ㅇㅇ(211.227) 04:33 36 0
2869560 Bob Dylan on The Fugs – CIA Man 발명도둑잡기(118.216) 04:29 9 0
2869558 저사람은 아침에도 점심에도 저녁에도 새벽에도있네 [1] ㅇㅇ(211.227) 04:17 25 0
2869556 군대 이야기 참 생각하면 좆같은게 동생 죽는거 군대때문에 못봄 [2] ㅆㅇㅆ(124.216) 04:13 39 0
2869554 이게 루비가 초기에 주장했던 임베디드를 다들 루비글을 안읽으니 ㅆㅇㅆ(124.216) 04:09 15 0
2869552 ㅆㅇㅆ아 군대에서처럼 살지 마라 [2] 프갤러(156.146) 04:05 44 0
2869550 펌쟁이가 임베떡밥있길래 글 써봄 [3] 프갤러(39.120) 03:50 35 0
2869549 20분 전쯤 내 갤럭시 S20 유튜브가 재생이 시작 안되서 발명도둑잡기(118.216) 03:50 17 0
2869548 3차원 시간 가설 사실이면 노벨상이고 혁명 발명도둑잡기(118.216) 03:47 11 0
2869547 제 방 책들 정리중입니다. 넥도리아(175.196) 03:36 25 0
2869545 민생지원금이 25만원인데 오른 집값은 2억5천 정도 발명도둑잡기(118.216) 03:01 17 0
2869543 오늘의 소설, 영화 실마리: 한국 언론에 침투한 각국의 스파이들 발명도둑잡기(118.216) 02:52 16 0
2869541 스카이데일리 고 고동석 편집국장 관련 미디어오늘 기사 발명도둑잡기(118.216) 02:42 32 0
2869540 이 부트캠프 신청했는데 괜찮은가요? [2] 프갤러(211.235) 02:26 48 0
2869539 개좆같다 이기 ㅋㅋㅋㅋㅋ [1] 루도그담당(58.239) 02:15 31 0
2869537 ios 가상머신 발명도둑잡기(118.216) 02:10 15 0
2869536 이걸 언제 다 읽고있냐 [2] 류도그담당(58.239) 02:08 49 0
2869535 APT 발명도둑잡기(118.216) 02:08 18 0
2869534 애초에 자본금이 개좆병신인데, 내가 자동매매해봤자 [3] ㅆㅇㅆ(124.216) 02:08 26 0
2869532 나 지금 목표가 이거거든? [4] ㅆㅇㅆ(124.216) 01:56 50 2
2869531 IDA 크랙 구해야하나 [2] 류도그담당(58.239) 01:47 43 0
2869529 비전공자, ㅈ문대, 복학생, 웹개발자 [8] 프갤러(93.152) 01:36 48 0
2869528 읽어도 읽어도 저 많은 천재들과 싸울 자신이 없다. [2] ㅆㅇㅆ(124.216) 01:30 41 0
2869527 프로그래밍 근데 할수록 자신감이 안 생긴다 ㅆㅇㅆ(124.216) 01:27 23 0
2869525 면접볼때마다 [4] 무관갤로그로 이동합니다. 01:07 40 0
2869524 CPP 코드 90%는 C++11 안전 기준 미달 맞음(논문있음) [1] ㅆㅇㅆ(124.216) 01:05 47 0
2869523 도로상태 훌륭 넥도리아(223.38) 01:04 13 0
2869522 동네 도로 환경 순찰 중 어머니폰으로 넥도리아(223.38) 01:01 15 0
2869521 2달 존버하고 받은 금액이 고작 ㅇㅇ(118.235) 00:57 43 0
2869520 내 방 온도 29.3도 발명도둑잡기(118.216) 00:57 15 0
2869519 7월 4일 4시 7월 5일 4시 한국 넥도리아(223.38) 00:55 21 0
2869518 치아교정 때문에 군것질이 약간 줄었다 발명도둑잡기(118.216) 00:55 15 0
2869517 아니, 비야네가 정의한 레거시 코드 기준이랑 다 떠먹여줘도 [1] ㅆㅇㅆ(124.216) 00:50 23 0
2869516 진보적인 외국 정부 부정선거 여론 언론공작은 CIA의 주특기다 발명도둑잡기(118.216) 00:47 18 0
2869515 그냥 차트맨아 내 글을 LLM 아무데나 복사붙여넣기하고 ㅆㅇㅆ(124.216) 00:42 19 0
2869514 가만 보니까 legacy라는 말을 병적으로 해석하는구만 [9] ㅇㅇ갤로그로 이동합니다. 00:40 50 0
2869513 나도 따당이처럼 잘하고 싶노 ㅆㅇㅆ(124.216) 00:39 13 0
2869512 [최우리의 비도 오고 그래서] 기후위기와 범죄의 상관관계 발명도둑잡기(118.216) 00:30 11 0
2869511 차트맨아 농담 아니고, 너 현역에 금융업계 종사 오래한건 알겠는데 ㅆㅇㅆ(124.216) 00:29 22 0
2869510 차트맨아 C++ 책좀 읽어라 왜곡하지말고 그냥 [10] ㅆㅇㅆ(124.216) 00:22 64 1
2869509 Ada, 러스트의 안전성 수준을 동일하게 제약할 때 루비갤로그로 이동합니다. 00:21 17 0
2869508 러스트 극성 지지자들의 '발작' 포인트 요약 루비갤로그로 이동합니다. 00:18 19 0
2869507 Ada vs. Rust: 동일 안전성 수준 코드 비교 루비갤로그로 이동합니다. 00:14 18 0
2869506 나님 흔들고 주무실게양..⭐+ ♥냥덩이♥갤로그로 이동합니다. 00:14 19 0
2869505 오픈소스 PR 날려 본 사람 있음? [1] 익명의따당이갤로그로 이동합니다. 00:13 28 0
2869504 Rust 코드 컴파일 논란: 명백한 허위 주장과 인신공격에 대한 반박 루비갤로그로 이동합니다. 00:10 18 0
2869502 러스트 설치도 못하는 저능아의 마지막 도피처. "llm 환각" 프갤러(110.8) 00:07 19 0
뉴스 ‘낙태권 옹호’ 릴리 앨런, “낙태 몇 번 했는지 기억 안 나…자주 임신해” 디시트렌드 07.03
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2