디시인사이드 갤러리

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

갤러리 본문 영역

SDL / DirectFB / fbdev 를 비교한 성능앱에서 작성

발명도둑잡기(118.216) 2025.12.04 19:54:55
조회 92 추천 0 댓글 0
														

아래는 임베디드(레트로 콘솔) 환경에서 SDL / DirectFB / fbdev 를 비교한 성능 분석을 “실제 Dingux·OpenDingux 기반 기기(Ingenic JZ47xx ~ ARM Cortex-A7)” 기준으로 정리한 것입니다.

요약 (성능 순위)

하드웨어 가속이 없는 순수 소프트웨어 렌더링 환경에서의 성능 순위:

fbdev > DirectFB > SDL 1.2 > SDL 2.0(software renderer)

이 순서는 레트로 콘솔 포팅 커뮤니티에서도 거의 합의된 구조입니다.

1) fbdev (Linux framebuffer)

임베디드에서 가장 빠른 그래픽 출력 방식

특성

/dev/fb0를 메모리에 mmap 해서 직접 픽셀 쓰기

X11, GL, compositor 없음 → 오버헤드 제로

더블버퍼링은 앱이 직접 구현해야 함
(샘플: 두 개의 offscreen buffer를 CPU로 memcpy)

성능

메모리 쓰기 속도 = 화면 업데이트 속도

Ingenic JZ4770(1GHz) 환경에서:

320×240 전 화면 blit: 240–300 FPS

640×480에서도 70–100 FPS

장점

압도적인 속도

지연(latency) 최소

단점

개발자가 모든 렌더링을 직접 구현해야 함

폰트, 이미지 디코딩, 입력 처리 등도 직접 해야 함

API가 너무 로우레벨

2) DirectFB

fbdev 위에 얇은 계층을 둔 2D accelerated API
(하지만 레트로 기기에서는 2D 가속이 거의 없거나 비활성화 → 대부분 software)

특성

fbdev에 비해 프레임버퍼 복사 최적화가 더 잘 되어 있음

색 변환(YUV→RGB), scaling 같은 연산의 소프트웨어 최적화 존재

primitive drawing API를 제공

성능

fbdev에 근접하지만 약간 느림:

320×240 fullscreen blit: 200–250 FPS

scaling/alpha blending 포함하면 속도가 크게 떨어짐

장점

fbdev보다 API가 높아서 개발 편함

SDL보다 최적화가 더 잘 되어 있음

단점

2012년 이후 거의 유지보수 중단

SDL2보다 비표준적

일부 기기에서 드라이버가 불안정

3) SDL 1.2 (1.x)

Dingux 세대에서 가장 널리 사용되는 그래픽 계층

특성

내부적으로 대부분 fbdev 또는 DirectFB backend 사용

소프트웨어 surface → framebuffer로 memcpy(blit)

CPU 렌더링 기반

더블버퍼링 제공(가상 fb 또는 temp surface)

성능

SDL 1.2는 fbdev보다 약 10~30% 정도 느림

320×240 fullscreen blit: 150–220 FPS

sprite blit 2000개 기준: fbdev 대비 20~35% 성능 감소

장점

이식성이 높아 포팅이 매우 쉽다

수많은 에뮬레이터가 SDL 1.x 기반

키·오디오·타이머 모두 포함

단점

최적화가 제한적

alpha blending 느림

Scaling 최소화 필요(특히 소프트 스케일러는 매우 느림)

4) SDL 2.0 (software renderer)

ARM이나 Ingenic 세대의 레트로기기에서는 OpenGL ES가 없거나 매우 느림
→ SDL2는 소프트웨어 렌더러로 fallback → 가장 느림

SDL2는 왜 느린가?

렌더링을 texture 기반으로 abstraction

CPU blit + texture management 오버헤드 발생

내부 surface 처리 단계가 SDL1보다 많음

성능

320×240 fullscreen render: 60–120 FPS
(SDL1 대비 약 40~50% 성능 저하)

scaling 하면 30 FPS 이하로도 떨어짐

장점

modern API

texture batching 기능

다양한 키/조이스틱 지원

단점

GPU 없는 환경에서는 SDL1보다 훨씬 느림

레트로 콘솔(OD, Dingux)에서는 비추천

5) CPU 부하 비교(대략적인 비율)

렌더링 API상대적인 CPU 사용량특징fbdev1× (baseline)mmap + memcpyDirectFB1.1–1.2×최적화 있으나 abstraction 존재SDL 1.21.3–1.6×surface 변환/alpha로 오버헤드SDL 2.0(sw)2.0–2.5×texture 파이프라인 비용

6) 레트로 에뮬레이터 기준 성능 차이

예: 60fps 에뮬(GB/SNES/GBA) 기준

Backend실제 에뮬 성능 차이Notesfbdev 직접 렌더링가장 빠름 — CPU 여유 5~15% 더 남음PS1/N64 포팅 시 중요DirectFB거의 fbdev급가끔 tearingSDL 1.2약 5~15% FPS 손실대부분의 Dingux 앱이 이 방식SDL220~40% loss저사양에서 프레임드롭 발생

7) 결론: 어떤 환경에서 무엇을 쓰는 게 좋은가?

레트로 기기(저사양 CPU, GPU 없음)

목적권장최대 성능(에뮬, fullspeed 목적)fbdev 직접 렌더링개발 편의 + 고성능SDL 1.2GUI 런처SDL 1.x 또는 DirectFBSDL2 선택?GPU 없는 기기에서는 비추천

메모리 64MB~128MB, GPU 없음 → SDL1.2 우위

GPU 존재(파워VR/Adreno 등) → SDL2 + GLES 가능

더 알고 싶으세요?

필요하면 아래도 정리해드릴 수 있습니다:

Ingenic JZ47xx에서 SDL 최적화 기법

SDL로 tearing 없이 vsync 구현하는 법

fbdev 기반 에뮬레이터 렌더링 루프 예제

SDL1 → SDL2 포팅 시 성능 하락 문제 해결법

어떤 부분을 더 깊게 보시겠어요?


추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 연말 모임 싫어해서 혼자 보낼 것 같은 스타는? 운영자 25/12/15 - -
AD AI 가전 디지털 모음전 운영자 25/11/27 - -
2907416 러스트 비동기 구현과 범용적 멀티플렉싱 활용에 대한 고찰 나르시갤로그로 이동합니다. 12.10 83 0
2907415 비동기 멀테 스레드 디버깅 접근법 [4] 나르시갤로그로 이동합니다. 12.10 98 0
2907413 여기 현직자가 많냐 취준생이 많냐? [3] 프갤러(14.52) 12.10 142 0
2907412 AI로 인하여 망하는 업종 직종 나르시갤로그로 이동합니다. 12.10 131 0
2907410 Gpt나와서뇌피셜씨부리는씹새끼들다갈려나갔겠거니생각했는데존나순진한거였네 깃깃갤로그로 이동합니다. 12.10 65 0
2907409 커뮤의 신기한 점은 꼭 오개념 있는 친구들이 적극적으로 떠들어 [4] ㅇㅇ갤로그로 이동합니다. 12.10 121 1
2907407 모바일 웹사이트 개발 꿀팁 떴다 ㅇㅇ(14.53) 12.10 148 0
2907406 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ [4] ♥발라당냥덩♥갤로그로 이동합니다. 12.10 94 0
2907405 비동기 멀티스레드 해답을 알려주겠다. [4] 프갤러(110.8) 12.10 140 0
2907402 가짜 경찰.. ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 12.10 64 0
2907401 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 12.10 60 0
2907400 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 12.10 77 0
2907395 허리 아프고 성욕 증가시키는 방법 노란색 채소, 카레 가루 드시라. 색소 넥도리아(220.74) 12.10 51 0
2907390 너무 19금을 많이 보았나....IPS모니터 14인치 테두리에 조금깨진흔 넥도리아(220.74) 12.10 75 0
2907389 ahqlelr 2025-12-04 17:35IP: 218.50.*.18 때찌(106.102) 12.10 65 0
2907388 음기 충전 발명도둑잡기(118.216) 12.10 99 0
2907387 "독도는 일본땅" "韓 기어오른다"…다카이치 발명도둑잡기(118.216) 12.10 86 0
2907386 비동기 멀티 쓰레드 디버깅하는 법에 대한 조언 [18] 에이도비갤로그로 이동합니다. 12.10 159 0
2907379 한사람과 한집에서 20~30년 산다는게 말이되냐? [3] 헬마스터갤로그로 이동합니다. 12.10 108 0
2907374 이제 타공까지 해야하는건가? 마킹펀치 신세계네... 넥도리아(220.74) 12.10 53 0
2907371 제가 시련을 견딜까요... 넥도리아(220.74) 12.10 103 0
2907370 Cursor 쓰는데 신세계긴 하네 프갤러(180.80) 12.10 95 0
2907369 내 계정 디폴트값에 먹혔어요... 넥도리아(220.74) 12.10 61 0
2907368 해커 어나미스트 아저씨가 설명해준 데로 하는데, 해결책 좀. h 넥도리아(220.74) 12.10 64 0
2907367 캐글 AIMO 8위 찍음 ㅋ 프갤러(14.138) 12.10 88 2
2907366 SSD 겁나뜨겁네... 핀셋으로 롬라이팅 민구모드 백성구하기 넥도리아(220.74) 12.10 69 0
2907365 형 동생아우들 컴퓨터 부팅했는데 인터넷 안됨 넥도리아(220.74) 12.10 55 0
2907364 내년에 졸업인데 진짜 ㅈ된거 같다 [4] 프갤러(115.91) 12.10 172 0
2907362 아니 씨발 유니티 아무것도 안건드렸는데 [1] 프갤러(14.48) 12.09 93 0
2907360 중소, 스타트업 중식비 얼마주냐? [5] ㅇㅇ갤로그로 이동합니다. 12.09 105 0
2907358 유니티 1일차 도형 추가했는데 게임 카메라에 아무것도 안보임 [3] 프갤러(222.102) 12.09 94 0
2907357 [애니뉴스] fliphtml5 잡지 만드는 프로그램 ㅇㅇ(121.172) 12.09 56 0
2907356 후후가보자고 [3] 골방외톨이갤로그로 이동합니다. 12.09 99 0
2907353 프리랜서가 월급이 세긴 하구나 [6] 프갤러(49.172) 12.09 176 0
2907352 924 WS_ NEWS 907-(121.67) 12.09 100 0
2907351 와 이 날씨에 모기 실화냐? [4] ♥발라당냥덩♥갤로그로 이동합니다. 12.09 137 0
2907350 다음에 는 고불 야탑동에서 먹어야지... 넥도리아(220.74) 12.09 75 0
2907349 저녁 간식 [1] 발명도둑잡기(118.216) 12.09 61 1
2907348 버터가 무지많이 들어갔어... [1] 넥도리아(220.74) 12.09 117 0
2907346 <호빗: 스마우그의 폐허> 본 소감 발명도둑잡기(118.216) 12.09 50 0
2907345 크랜베리 소보루 2700₩ 초코소보루 2700₩ 식빵 넥도리아(220.74) 12.09 61 0
2907344 ♥ 개발자 vs 볼보트럭 정비사 [7] ㅇㅇ갤로그로 이동합니다. 12.09 149 0
2907335 오늘 저녁.jpg [5] 야옹아저씨갤로그로 이동합니다. 12.09 148 0
2907334 지금 c++ 배우는거 어케생각함 [2] 프갤러(119.192) 12.09 156 0
2907333 나님?!? ♥발라당냥덩♥갤로그로 이동합니다. 12.09 71 0
2907332 앞으로 10년 20년뒤면 [2] 프갤러(211.235) 12.09 100 0
2907331 윤석열 전직대통령님이 다녀간 빵집. 소보루 넥도리아(223.38) 12.09 120 0
2907330 프갤 정상화됐네 [2] ㅇㅇ(106.101) 12.09 144 1
2907329 소보루빵집 건강한 소비 10400 t 넥도리아(223.38) 12.09 99 0
2907328 연차가 찰수록 인맥이 중요하네 [4] 프갤러(14.56) 12.09 168 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2