한국어
Qt
 

Embedded Linux 에서 Qt 및 Graphics Stack

운영자 2020.05.27 12:55 조회 수 : 720

Qt5의 구조와 Integration

 
Qt5 Framework는 비GUI 적인 기능을 포함하는 Core와 플랫폼 윈도우 추상 레이어인 QPA 를 기반으로 Widget 및 그래픽 요소를 포함하는 Qt GUI구조를 이룬다. 여기서 QPA(Qt Platform Abstraction)는 플랫폼 기본 윈도우 시스템의 추상 레이어로써 플러그인 형태로 구현되며 Qt Application 시작 시 동적으로 로드된다.
 
기본으로 제공되는 주요 플러그인들이 있으며 다음과 같다.
  1. linuxfb: Linux Framebuffer
  2. EGLFS: OpenGL / OpenGL ES 를 위한 EGL 플랫폼 인터페이스.
  3. DirectFB: 가속 렌더링 지원 기능을 갖춘 경량 윈도우 시스템.
  4. X11/XCB: 전통적 리눅스 X 윈도우 시스템을 위한 것으로 XCB library를 사용.
  5. Wayland: OpenGL/ES 를 사용하는 경량의 리눅스 윈도우 시스템.
 이 중 EGLFS는 EGL 인터페이스를 사용하여 하나의 전체화면크기 창을 생성하는 것으로 GPU를 포함하고 OpenGL ES를 지원하는 임베디드 리눅스 장치에서 멀티 윈도우 및 응용프로그램이 필요 없는 요구사항에서 적합하다. EGLFS에는 몇 가지 기본으로 제공되는 포트가 있는데 다음과 같다.
  1. KMS (GBM): Kernel Mode Setting (DRM) with Mesa's Generic Buffer Management
  2. KMS (EGLDevice): Kernel Mode Setting with NVidia's EGLDevice
  3. viv, viv_wl: Vivante's framebuffer API
  4. brcm: Broadcom's framebuffer API for Raspberry PI
  5. mali: Framebuffer API for Mali chips
OpenGL ES 2.0, 3.0 및 EGL을 지원하는경우 기본으로 제공되는 EGLFS를 사용하거나 따로 개발할 수 있다. 아래의 다이어그램은 EGLFS의 QEglFSVivIntegrationPlugin 을 구현하는 클래스 관계를 나타낸 것이다. 플랫폼 서페이스 생성에 대한 공통적인 인터페이스 사용을 위해 추상 클래스를 서브클래싱하여 플러그인을 구현한다.
image.png
 
아래의 리스트는 QEglFSVivIntegration 클래스 구현의 일부분이다. 플러그인은 EGL/eglvivante.h 를 포함하고 EGL인터페이스를 통해 초기화, 표면을 생성, 삭제등을 구현한다.
#include <EGL/eglvivante.h>
…
void QEglFSVivIntegration::platformInit()
{
    QEglFSDeviceIntegration::platformInit();
    int width, height;
...
#ifdef Q_OS_INTEGRITY
    VivanteInit();
    mNativeDisplay = fbGetDisplay();
#else
    mNativeDisplay =  static_cast<EGLNativeDisplayType>(fbGetDisplayByIndex(framebufferIndex()));
#endif
    fbGetDisplayGeometry(mNativeDisplay, &width, &height);
      mScreenSize.setHeight(height);
      mScreenSize.setWidth(width);
}
...
EGLNativeWindowType  QEglFSVivIntegration::createNativeWindow(QPlatformWindow *window, const QSize  &size, const QSurfaceFormat &format)
{
...
    EGLNativeWindowType  eglWindow = static_cast<EGLNativeWindowType>(fbCreateWindow(mNativeDisplay, 0, 0, size.width(),  size.height()));
    return eglWindow;
}
void QEglFSVivIntegration::destroyNativeWindow(EGLNativeWindowType  window)
{
    fbDestroyWindow(window);
}
 시스템 전체 범위로 확대하여 구조를 파악할 필요가 있다. 아래의 그림은 임베디드 리눅스에서 프레임버퍼 장치를 기반으로 Qt Framework의 EGLFS와 OpenGL ES / EGL을 사용하는 그래픽 스택이다.
 

qt.png

 

OpenGL ES / EGL이 어떻게 사용되고 또 그 흐름을 간단하게 설명하면 다음과 같다.
  1. 먼저 Qt 는 Application이 실행될 때 QPA 플러그인으로 EGLFS를 사용하여 EGL Surface를 생성한다.
  2. 응용프로그램에서QOpenGLWidget 또는 QML을 사용하는 GUI는 OpenGL ES를 통해 H/W가속이 먼저 이뤄진다.
  3. 그밖에 PaintEngine으로 그려진 그 외의 그래픽 요소들(QWidget)을 텍스처로 만들고 그것들을 QPA 플러그인(EGLFS)에서 최종 합성한다.
  4. GPU결과는 EGL 인터페이스를 통해 리눅스 프레임버퍼장치의 DMA 버퍼에 쓰고 DMA컨트롤러에 의해 Display컨트롤러로 보낸다.
번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 87717
119 안드로이드 가상장치 사용 file makersweb 2019.01.13 1184
118 QMake 프로젝트를 CMake 프로젝트로 변환 with qmake2cmake makersweb 2022.09.17 1192
117 Qml에서 커튼효과 구현 예제 - Shader Effects file 운영자 2018.12.05 1213
116 QProcess 예제 (프로그램 재시작) file makersweb 2023.01.25 1238
115 Qt 6의 비동기 API makersweb 2020.10.19 1316
114 많은 리소스를 사용하는 Qt프로젝트에서 고려해봐야 할 qmake 옵션 makersweb 2019.10.11 1319
113 Qt 하이브리드 애플리케이션(Hybrid App) 개발 file makersweb 2023.02.08 1327
112 재진입(Reentrancy) 및 스레드 안전성(Thread-Safety) makersweb 2020.04.19 1354
111 Qt 스마트 포인터 (QSharedPointer, QScopedPointer, QPointer) makersweb 2022.08.18 1368
110 웹기반 Qt Design Viewer [2] file makersweb 2019.10.23 1397
109 tslib의 ts_calibrate를 응용해서 Qt로 터치보정기능 구현 file makersweb 2019.04.06 1465
108 qInstallMessageHandler를 이용한 디버그 메세지 출력 제어하기 makersweb 2019.02.25 1477
107 QThread 및 QMutex 예제 makersweb 2021.01.12 1481
106 Qbs에 대한 소개와 설치하는 방법 makersweb 2019.10.09 1488
105 싱글터치 스크린 및 임베디드 리눅스 기반에서 Qt 터치입력 makersweb 2018.12.24 1516
104 QML과 JavaScript 의 숫자 관련 내장된 함수 makersweb 2021.03.28 1561
103 Qt Quick 3D 소개 makersweb 2019.11.09 1584
102 QML에서 undefined를 확인하는 방법 makersweb 2017.11.29 1609
101 ApplicationWindow 와 메뉴바(MenuBar)구성 file makersweb 2020.01.04 1619
100 Widgets(C++) 기반의 기본 스타일을 Dark 테마 및 Material 디자인 스타일로 바꾸기 file makersweb 2023.01.28 1633