Commit c427bc0a3a3ab39680ce591774b4766ee5d4f46e
Exists in
master
and in
2 other branches
Merge branch 'master' of 192.168.10.12:falinux/1611_0007_prime_oven
Showing
12 changed files
Show diff stats
README.md
... | ... | @@ -45,7 +45,9 @@ |
45 | 45 | * 부트로더 디렉토리로 이동한다. |
46 | 46 | |
47 | 47 | $ cd bootloader/u-boot_2015_04 |
48 | - $ source ../../env-4.9.4.env # (이미 실행하였다면 하지 않아도 된다) | |
48 | + $ cd ../../ | |
49 | + $ source env-4.9.4.env # (이미 실행하였다면 하지 않아도 된다) | |
50 | + $ cd bootloader/u-boot_2015_04 | |
49 | 51 | |
50 | 52 | * u-boot 환경 파일 |
51 | 53 | |
... | ... | @@ -72,7 +74,10 @@ |
72 | 74 | * 커널 디렉토리로 이동한다. |
73 | 75 | |
74 | 76 | $ cd kernel/linux-imx6_3.14.28 |
75 | - $ source ../../env-4.9.4.env # (이미 실행하였다면 하지 않아도 된다) | |
77 | + $ cd ../../ | |
78 | + $ source env-4.9.4.env # (이미 실행하였다면 하지 않아도 된다) | |
79 | + $ cd kernel/linux-imx6_3.14.28 | |
80 | + | |
76 | 81 | |
77 | 82 | * kernel 환경 파일 |
78 | 83 | |
... | ... | @@ -101,6 +106,10 @@ |
101 | 106 | * buildroot 디렉토리 buildroot 로 이동한다. |
102 | 107 | |
103 | 108 | $ cd buildroot/buildroot-2016.08.1 |
109 | + $ cd ../../ | |
110 | + $ source env-4.9.4.env # (이미 실행하였다면 하지 않아도 된다) | |
111 | + $ cd buildroot/buildroot-2016.08.1 | |
112 | + | |
104 | 113 | |
105 | 114 | * 컴파일은 make.sh 를 사용한다. |
106 | 115 | |
... | ... | @@ -165,13 +174,12 @@ |
165 | 174 | ## [파티션] |
166 | 175 | --------------------------- |
167 | 176 | |
168 | - start size desc | |
169 | - ---------- ---------- ------------------ | |
170 | - 00-MB 64-MB reserved area | |
171 | - 64-MB 64-MB partition#0, FAT32 : BOOT0 | |
172 | - 128-MB 64-MB partition#1, FAT32 : BOOT1 | |
173 | - 192-MB 128-MB partition#2, ext4 : APP | |
174 | - 320-MB all partition#3, ext4 : DATA | |
177 | + start size desc | |
178 | + ---------- ---------- ------------------ | |
179 | + 00-MB 64-MB reserved area | |
180 | + 64-MB 192-MB partition#0, ext4 : BOOT0 | |
181 | + 256-MB 2048-MB partition#1, ext4 : APP | |
182 | + 2304-MB all partition#2, ext4 : DATA | |
175 | 183 | |
176 | 184 | ------------------------------------------ |
177 | 185 | 00-MB 64-MB reserved area | ... | ... |
buildroot/buildroot-2016.08.1/board/falinux/prime_oven/rootfs_overlay/root/.falinux/mk-mmc-part.sh
... | ... | @@ -5,34 +5,35 @@ BDEV=/dev/mmcblk0 |
5 | 5 | PART1=p1 |
6 | 6 | PART2=p2 |
7 | 7 | PART3=p3 |
8 | -PART4=p4 | |
9 | 8 | |
10 | 9 | umount ${BDEV}${PART1} |
11 | 10 | umount ${BDEV}${PART2} |
12 | 11 | umount ${BDEV}${PART3} |
13 | -umount ${BDEV}${PART4} | |
14 | 12 | |
15 | 13 | echo "==== make partitions ===============================" |
16 | -fdisk -S1 -H1 ${BDEV} << EOF | |
14 | +## start stop desc | |
15 | +## ---------- ---------- ------------------ | |
16 | +## 00-MB 64-MB reserved area | |
17 | +## 64-MB 192-MB partition#0, ext4 : BOOT0 | |
18 | +## 256-MB 2048-MB partition#1, ext4 : APP | |
19 | +## 2304-MB all partition#2, ext4 : DATA | |
20 | +## | |
21 | +fdisk ${BDEV} << EOF | |
17 | 22 | o |
18 | 23 | n |
19 | 24 | p |
20 | 25 | 1 |
21 | -131072 | |
22 | -196607 | |
26 | +2048 | |
27 | +8191 | |
23 | 28 | n |
24 | 29 | p |
25 | 30 | 2 |
26 | -196608 | |
27 | -262143 | |
31 | +8192 | |
32 | +73727 | |
28 | 33 | n |
29 | 34 | p |
30 | 35 | 3 |
31 | -262144 | |
32 | -524287 | |
33 | -n | |
34 | -p | |
35 | -524288 | |
36 | +73728 | |
36 | 37 | |
37 | 38 | t |
38 | 39 | 1 |
... | ... | @@ -46,8 +47,7 @@ EOF |
46 | 47 | ## format partitions |
47 | 48 | echo "==== format partitions =============================" |
48 | 49 | |
49 | -mkfs.fat ${BDEV}${PART1} -n BOOT0 | |
50 | -mkfs.fat ${BDEV}${PART2} -n BOOT1 | |
51 | -mkfs.ext4 -F ${BDEV}${PART3} -L APP | |
52 | -mkfs.ext4 -F ${BDEV}${PART4} -L DATA | |
50 | +mkfs.ext4 -F ${BDEV}${PART1} -L BOOT0 | |
51 | +mkfs.ext4 -F ${BDEV}${PART2} -L APP | |
52 | +mkfs.ext4 -F ${BDEV}${PART3} -L DATA | |
53 | 53 | ... | ... |
buildroot/buildroot-2016.08.1/board/falinux/prime_oven/rootfs_overlay/root/.prime_oven/.buildroot_version
buildroot/buildroot-2016.08.1/configs/imx6s_prime_oven_qt5_defconfig
... | ... | @@ -0,0 +1,77 @@ |
1 | +BR2_arm=y | |
2 | +BR2_cortex_a9=y | |
3 | +BR2_ARM_ENABLE_NEON=y | |
4 | +BR2_ARM_ENABLE_VFP=y | |
5 | +BR2_ARM_FPU_NEON=y | |
6 | +BR2_GLOBAL_PATCH_DIR="board/freescale/imx6sabre/patches" | |
7 | +BR2_TOOLCHAIN_EXTERNAL=y | |
8 | +BR2_TOOLCHAIN_EXTERNAL_CUSTOM=y | |
9 | +BR2_TOOLCHAIN_EXTERNAL_PATH="$(BR_TOOLCHAIN_PATH)/usr" | |
10 | +BR2_TOOLCHAIN_EXTERNAL_CUSTOM_PREFIX="$(BR_TOOLCHAIN_PREFIX)" | |
11 | +BR2_TOOLCHAIN_EXTERNAL_GCC_4_9=y | |
12 | +BR2_TOOLCHAIN_EXTERNAL_HEADERS_3_14=y | |
13 | +BR2_TOOLCHAIN_EXTERNAL_CUSTOM_GLIBC=y | |
14 | +BR2_TOOLCHAIN_EXTERNAL_CXX=y | |
15 | +BR2_TARGET_GENERIC_HOSTNAME="imx6s" | |
16 | +BR2_TARGET_GENERIC_ISSUE="Welcome to falinux" | |
17 | +BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_MDEV=y | |
18 | +BR2_TARGET_GENERIC_ROOT_PASSWD="root" | |
19 | +BR2_SYSTEM_BIN_SH_BASH=y | |
20 | +BR2_TARGET_GENERIC_GETTY_PORT="ttymxc0" | |
21 | +BR2_PACKAGE_BUSYBOX_SHOW_OTHERS=y | |
22 | +BR2_PACKAGE_BUSYBOX_WATCHDOG=y | |
23 | +BR2_PACKAGE_ALSA_UTILS=y | |
24 | +BR2_PACKAGE_ALSA_UTILS_AMIXER=y | |
25 | +BR2_PACKAGE_ALSA_UTILS_APLAY=y | |
26 | +BR2_PACKAGE_DOSFSTOOLS=y | |
27 | +BR2_PACKAGE_DOSFSTOOLS_MKFS_FAT=y | |
28 | +BR2_PACKAGE_E2TOOLS=y | |
29 | +BR2_PACKAGE_MMC_UTILS=y | |
30 | +BR2_PACKAGE_FBSET=y | |
31 | +BR2_PACKAGE_FB_TEST_APP=y | |
32 | +BR2_PACKAGE_FBV=y | |
33 | +BR2_PACKAGE_QT5=y | |
34 | +BR2_PACKAGE_QT5BASE_LICENSE_APPROVED=y | |
35 | +BR2_PACKAGE_QT5BASE_CONCURRENT=y | |
36 | +BR2_PACKAGE_QT5BASE_SQLITE_SYSTEM=y | |
37 | +BR2_PACKAGE_QT5BASE_WIDGETS=y | |
38 | +BR2_PACKAGE_QT5BASE_DEFAULT_QPA="linuxfb" | |
39 | +BR2_PACKAGE_QT5BASE_FONTCONFIG=y | |
40 | +BR2_PACKAGE_QT5BASE_GIF=y | |
41 | +BR2_PACKAGE_QT5BASE_JPEG=y | |
42 | +BR2_PACKAGE_QT5BASE_PNG=y | |
43 | +BR2_PACKAGE_QT5BASE_ICU=y | |
44 | +BR2_PACKAGE_QT5BASE_TSLIB=y | |
45 | +BR2_PACKAGE_QT5MULTIMEDIA=y | |
46 | +BR2_PACKAGE_QJSON=y | |
47 | +BR2_PACKAGE_FREESCALE_IMX=y | |
48 | +BR2_PACKAGE_FREESCALE_IMX_PLATFORM_IMX6Q=y | |
49 | +BR2_PACKAGE_IMX_GPU_VIV=y | |
50 | +BR2_PACKAGE_I2C_TOOLS=y | |
51 | +BR2_PACKAGE_MEMTESTER=y | |
52 | +BR2_PACKAGE_LIBIMXVPUAPI=y | |
53 | +BR2_PACKAGE_LIBGLIB2=y | |
54 | +BR2_PACKAGE_ETHTOOL=y | |
55 | +BR2_PACKAGE_IPERF=y | |
56 | +BR2_PACKAGE_IW=y | |
57 | +BR2_PACKAGE_LRZSZ=y | |
58 | +BR2_PACKAGE_OPENSSH=y | |
59 | +BR2_PACKAGE_WGET=y | |
60 | +BR2_PACKAGE_WHOIS=y | |
61 | +BR2_PACKAGE_WIRELESS_TOOLS=y | |
62 | +BR2_PACKAGE_WIRELESS_TOOLS_LIB=y | |
63 | +BR2_PACKAGE_WPA_SUPPLICANT=y | |
64 | +BR2_PACKAGE_WPA_SUPPLICANT_AP_SUPPORT=y | |
65 | +BR2_PACKAGE_WPA_SUPPLICANT_WIFI_DISPLAY=y | |
66 | +BR2_PACKAGE_WPA_SUPPLICANT_AUTOSCAN=y | |
67 | +BR2_PACKAGE_WPA_SUPPLICANT_EAP=y | |
68 | +BR2_PACKAGE_WPA_SUPPLICANT_HOTSPOT=y | |
69 | +BR2_PACKAGE_WPA_SUPPLICANT_DEBUG_SYSLOG=y | |
70 | +BR2_PACKAGE_WPA_SUPPLICANT_WPS=y | |
71 | +BR2_PACKAGE_WPA_SUPPLICANT_CLI=y | |
72 | +BR2_PACKAGE_WPA_SUPPLICANT_WPA_CLIENT_SO=y | |
73 | +BR2_PACKAGE_WPA_SUPPLICANT_PASSPHRASE=y | |
74 | +BR2_TARGET_ROOTFS_EXT2=y | |
75 | +BR2_TARGET_ROOTFS_EXT2_BLOCKS=131072 | |
76 | +BR2_TARGET_ROOTFS_EXT2_GZIP=y | |
77 | +# BR2_TARGET_ROOTFS_TAR is not set | ... | ... |
buildroot/buildroot-2016.08.1/configs/imx6s_prime_oven_qt5_gst_defconfig
... | ... | @@ -1,58 +0,0 @@ |
1 | -BR2_arm=y | |
2 | -BR2_cortex_a9=y | |
3 | -BR2_ARM_ENABLE_NEON=y | |
4 | -BR2_ARM_ENABLE_VFP=y | |
5 | -BR2_ARM_FPU_NEON=y | |
6 | -BR2_GLOBAL_PATCH_DIR="board/freescale/imx6sabre/patches" | |
7 | -BR2_TOOLCHAIN_EXTERNAL=y | |
8 | -BR2_TOOLCHAIN_EXTERNAL_CUSTOM=y | |
9 | -BR2_TOOLCHAIN_EXTERNAL_PATH="$(BR_TOOLCHAIN_PATH)/usr" | |
10 | -BR2_TOOLCHAIN_EXTERNAL_CUSTOM_PREFIX="$(BR_TOOLCHAIN_PREFIX)" | |
11 | -BR2_TOOLCHAIN_EXTERNAL_GCC_4_9=y | |
12 | -BR2_TOOLCHAIN_EXTERNAL_HEADERS_3_14=y | |
13 | -BR2_TOOLCHAIN_EXTERNAL_CUSTOM_GLIBC=y | |
14 | -BR2_TOOLCHAIN_EXTERNAL_CXX=y | |
15 | -BR2_TARGET_GENERIC_HOSTNAME="imx6s" | |
16 | -BR2_TARGET_GENERIC_ISSUE="Welcome to falinux" | |
17 | -BR2_TARGET_GENERIC_ROOT_PASSWD="root" | |
18 | -BR2_SYSTEM_BIN_SH_BASH=y | |
19 | -BR2_TARGET_GENERIC_GETTY_PORT="ttymxc0" | |
20 | -BR2_PACKAGE_BUSYBOX_SHOW_OTHERS=y | |
21 | -BR2_PACKAGE_GSTREAMER1=y | |
22 | -BR2_PACKAGE_GST1_PLUGINS_GOOD=y | |
23 | -BR2_PACKAGE_GST1_PLUGINS_GOOD_JPEG=y | |
24 | -BR2_PACKAGE_GST1_PLUGINS_GOOD_PNG=y | |
25 | -BR2_PACKAGE_GST1_PLUGINS_GOOD_PLUGIN_ALPHA=y | |
26 | -BR2_PACKAGE_GST1_PLUGINS_GOOD_PLUGIN_FLV=y | |
27 | -BR2_PACKAGE_GST1_PLUGINS_GOOD_PLUGIN_V4L2=y | |
28 | -BR2_PACKAGE_GST1_PLUGINS_GOOD_PLUGIN_V4L2_PROBE=y | |
29 | -BR2_PACKAGE_GST1_IMX=y | |
30 | -BR2_PACKAGE_GST1_LIBAV=y | |
31 | -BR2_PACKAGE_GDB=y | |
32 | -BR2_PACKAGE_DOSFSTOOLS=y | |
33 | -BR2_PACKAGE_DOSFSTOOLS_MKFS_FAT=y | |
34 | -BR2_PACKAGE_E2TOOLS=y | |
35 | -BR2_PACKAGE_QT5=y | |
36 | -BR2_PACKAGE_QT5BASE_LICENSE_APPROVED=y | |
37 | -BR2_PACKAGE_QT5BASE_EXAMPLES=y | |
38 | -BR2_PACKAGE_QT5BASE_WIDGETS=y | |
39 | -BR2_PACKAGE_QT5BASE_FONTCONFIG=y | |
40 | -BR2_PACKAGE_QT5BASE_GIF=y | |
41 | -BR2_PACKAGE_QT5BASE_JPEG=y | |
42 | -BR2_PACKAGE_QT5BASE_PNG=y | |
43 | -BR2_PACKAGE_QT5MULTIMEDIA=y | |
44 | -BR2_PACKAGE_FREESCALE_IMX=y | |
45 | -BR2_PACKAGE_FREESCALE_IMX_PLATFORM_IMX6Q=y | |
46 | -BR2_PACKAGE_FIRMWARE_IMX=y | |
47 | -BR2_PACKAGE_I2C_TOOLS=y | |
48 | -BR2_PACKAGE_ALSA_LIB=y | |
49 | -BR2_PACKAGE_TSLIB=y | |
50 | -BR2_PACKAGE_ETHTOOL=y | |
51 | -BR2_PACKAGE_IPERF3=y | |
52 | -BR2_PACKAGE_LRZSZ=y | |
53 | -BR2_PACKAGE_OPENSSH=y | |
54 | -BR2_PACKAGE_WGET=y | |
55 | -BR2_TARGET_ROOTFS_EXT2=y | |
56 | -BR2_TARGET_ROOTFS_EXT2_BLOCKS=131072 | |
57 | -BR2_TARGET_ROOTFS_EXT2_GZIP=y | |
58 | -# BR2_TARGET_ROOTFS_TAR is not set |
buildroot/buildroot-2016.08.1/make.sh
... | ... | @@ -18,8 +18,8 @@ TOOLCHAIN_DEFCONFIG_FILE=${TOOLCHAIN_DEFCONFIG_FILE/-/_} |
18 | 18 | QT4_GST_DEFCONFIG_FILE=${FA_CHIPSET}_${FA_PRODUCT}_qt4_gst_defconfig |
19 | 19 | QT4_GST_DEFCONFIG_FILE=${QT4_GST_DEFCONFIG_FILE/-/_} |
20 | 20 | |
21 | -QT5_GST_DEFCONFIG_FILE=${FA_CHIPSET}_${FA_PRODUCT}_qt5_gst_defconfig | |
22 | -QT5_GST_DEFCONFIG_FILE=${QT4_GST_DEFCONFIG_FILE/-/_} | |
21 | +QT5_DEFCONFIG_FILE=${FA_CHIPSET}_${FA_PRODUCT}_qt5_defconfig | |
22 | +QT5_DEFCONFIG_FILE=${QT4_GST_DEFCONFIG_FILE/-/_} | |
23 | 23 | |
24 | 24 | |
25 | 25 | OUTPUT_DIR=../output-buildroot-2016.08.1 |
... | ... | @@ -35,7 +35,7 @@ case $1 in |
35 | 35 | echo " defconfig : reload config" |
36 | 36 | echo " toolchain : apply config file for toolchain" |
37 | 37 | echo " qt4_gst : apply config file for QT4/Gstreamer" |
38 | - echo " qt5_gst : apply config file for QT5/Gstreamer" | |
38 | + echo " qt5 : apply config file for QT5" | |
39 | 39 | echo " image : generate ramdisk image file" |
40 | 40 | echo " clean-target : clean target directory" |
41 | 41 | echo " distclean : delete all non-source files (.config)" |
... | ... | @@ -53,9 +53,9 @@ case $1 in |
53 | 53 | echo CONFIG: ${QT4_GST_DEFCONFIG_FILE} |
54 | 54 | make O=${OUTPUT_DIR} ${QT4_GST_DEFCONFIG_FILE} |
55 | 55 | ;; |
56 | - qt5_gst) | |
57 | - echo CONFIG: ${QT5_GST_DEFCONFIG_FILE} | |
58 | - make O=${OUTPUT_DIR} ${QT5_GST_DEFCONFIG_FILE} | |
56 | + qt5) | |
57 | + echo CONFIG: ${QT5_DEFCONFIG_FILE} | |
58 | + make O=${OUTPUT_DIR} ${QT5_DEFCONFIG_FILE} | |
59 | 59 | ;; |
60 | 60 | defconfig) |
61 | 61 | echo CONFIG: ${DEFCONFIG_FILE} | ... | ... |
buildroot/buildroot-2016.08.1/package/freescale-imx/imx-gpu-viv/imx-gpu-viv.hash
1 | -sha256 8f79ce562d8ac1efb0a2af403b405541f98c55ae1631a18a3d7fad3224dfb44b imx-gpu-viv-5.0.11.p8.4-hfp.bin | |
1 | +#sha256 8f79ce562d8ac1efb0a2af403b405541f98c55ae1631a18a3d7fad3224dfb44b imx-gpu-viv-5.0.11.p8.4-hfp.bin | |
2 | +sha256 0591b495cd1c2547ae007d405b90729e2fb90603a5728b39d1a99cb4e1cf1eb4 imx-gpu-viv-5.0.11.p4.5-hfp.bin | |
3 | + | ... | ... |
buildroot/buildroot-2016.08.1/package/freescale-imx/imx-gpu-viv/imx-gpu-viv.mk
... | ... | @@ -4,7 +4,9 @@ |
4 | 4 | # |
5 | 5 | ################################################################################ |
6 | 6 | |
7 | -IMX_GPU_VIV_VERSION = 5.0.11.p8.4-hfp | |
7 | +#IMX_GPU_VIV_VERSION = 5.0.11.p8.4-hfp | |
8 | +IMX_GPU_VIV_VERSION = 5.0.11.p4.5-hfp | |
9 | + | |
8 | 10 | IMX_GPU_VIV_SITE = $(FREESCALE_IMX_SITE) |
9 | 11 | IMX_GPU_VIV_SOURCE = imx-gpu-viv-$(IMX_GPU_VIV_VERSION).bin |
10 | 12 | ... | ... |
buildroot/buildroot-2016.08.1/package/qt5/qt5base/0008-linuxfb-rotate.patch
... | ... | @@ -1,102 +0,0 @@ |
1 | -diff --git a/src/plugins/platforms/linuxfb/qlinuxfbscreen.cpp b/src/plugins/platforms/linuxfb/qlinuxfbscreen.cpp | |
2 | ---- a/src/plugins/platforms/linuxfb/qlinuxfbscreen.cpp 2017-03-06 15:43:16.205457343 +0900 | |
3 | -+++ b/src/plugins/platforms/linuxfb/qlinuxfbscreen.cpp 2017-03-06 13:38:20.857076470 +0900 | |
4 | -@@ -280,7 +280,7 @@ | |
5 | - } | |
6 | - | |
7 | - QLinuxFbScreen::QLinuxFbScreen(const QStringList &args) | |
8 | -- : mArgs(args), mFbFd(-1), mTtyFd(-1), mBlitter(0) | |
9 | -+ : mArgs(args), mFbFd(-1), mTtyFd(-1), mBlitter(0), mRotation(0) | |
10 | - { | |
11 | - mMmap.data = 0; | |
12 | - } | |
13 | -@@ -306,6 +306,7 @@ | |
14 | - QRegularExpression mmSizeRx(QLatin1String("mmsize=(\\d+)x(\\d+)")); | |
15 | - QRegularExpression sizeRx(QLatin1String("size=(\\d+)x(\\d+)")); | |
16 | - QRegularExpression offsetRx(QLatin1String("offset=(\\d+)x(\\d+)")); | |
17 | -+ QRegularExpression rotationRx(QLatin1String("rotation=(0|90|180|270)")); | |
18 | - | |
19 | - QString fbDevice, ttyDevice; | |
20 | - QSize userMmSize; | |
21 | -@@ -327,6 +328,8 @@ | |
22 | - ttyDevice = match.captured(1); | |
23 | - else if (arg.contains(fbRx, &match)) | |
24 | - fbDevice = match.captured(1); | |
25 | -+ else if (arg.contains(rotationRx, &match)) | |
26 | -+ mRotation = match.captured(1).toInt(); | |
27 | - } | |
28 | - | |
29 | - if (fbDevice.isEmpty()) { | |
30 | -@@ -365,9 +368,17 @@ | |
31 | - mDepth = determineDepth(vinfo); | |
32 | - mBytesPerLine = finfo.line_length; | |
33 | - QRect geometry = determineGeometry(vinfo, userGeometry); | |
34 | -+ QRect originalGeometry = geometry; | |
35 | -+ if( mRotation == 90 || mRotation == 270 ) | |
36 | -+ { | |
37 | -+ int tmp = geometry.width(); | |
38 | -+ geometry.setWidth(geometry.height()); | |
39 | -+ geometry.setHeight(tmp); | |
40 | -+ } | |
41 | -+ | |
42 | - mGeometry = QRect(QPoint(0, 0), geometry.size()); | |
43 | - mFormat = determineFormat(vinfo, mDepth); | |
44 | -- mPhysicalSize = determinePhysicalSize(vinfo, userMmSize, geometry.size()); | |
45 | -+ mPhysicalSize = determinePhysicalSize(vinfo, userMmSize, originalGeometry.size()); | |
46 | - | |
47 | - // mmap the framebuffer | |
48 | - mMmap.size = finfo.smem_len; | |
49 | -@@ -377,11 +388,11 @@ | |
50 | - return false; | |
51 | - } | |
52 | - | |
53 | -- mMmap.offset = geometry.y() * mBytesPerLine + geometry.x() * mDepth / 8; | |
54 | -+ mMmap.offset = originalGeometry.y() * mBytesPerLine + originalGeometry.x() * mDepth / 8; | |
55 | - mMmap.data = data + mMmap.offset; | |
56 | - | |
57 | - QFbScreen::initializeCompositor(); | |
58 | -- mFbScreenImage = QImage(mMmap.data, geometry.width(), geometry.height(), mBytesPerLine, mFormat); | |
59 | -+ mFbScreenImage = QImage(mMmap.data, originalGeometry.width(), originalGeometry.height(), mBytesPerLine, mFormat); | |
60 | - | |
61 | - mCursor = new QFbCursor(this); | |
62 | - | |
63 | -@@ -409,8 +420,27 @@ | |
64 | - mBlitter->setCompositionMode(QPainter::CompositionMode_Source); | |
65 | - | |
66 | - for (int i = 0; i < rects.size(); ++i) | |
67 | -+ { | |
68 | -+ if( mRotation == 90 || mRotation == 270 ) | |
69 | -+ { | |
70 | -+ mBlitter->translate(mGeometry.height()/2, mGeometry.width()/2); | |
71 | -+ } | |
72 | -+ else if( mRotation == 180 ) | |
73 | -+ { | |
74 | -+ mBlitter->translate(mGeometry.width()/2, mGeometry.height()/2); | |
75 | -+ } | |
76 | -+ | |
77 | -+ if( mRotation != 0 ) | |
78 | -+ { | |
79 | -+ mBlitter->rotate(mRotation); | |
80 | -+ mBlitter->translate(-mGeometry.width()/2, -mGeometry.height()/2); | |
81 | -+ } | |
82 | -+ | |
83 | - mBlitter->drawImage(rects[i], *mScreenImage, rects[i]); | |
84 | - | |
85 | -+ mBlitter->resetTransform(); | |
86 | -+ } | |
87 | -+ | |
88 | - return touched; | |
89 | - } | |
90 | - | |
91 | -diff --git a/src/plugins/platforms/linuxfb/qlinuxfbscreen.h b/src/plugins/platforms/linuxfb/qlinuxfbscreen.h | |
92 | ---- a/src/plugins/platforms/linuxfb/qlinuxfbscreen.h 2016-05-26 00:46:17.000000000 +0900 | |
93 | -+++ b/src/plugins/platforms/linuxfb/qlinuxfbscreen.h 2017-03-06 13:38:20.857076470 +0900 | |
94 | -@@ -58,6 +58,7 @@ | |
95 | - QStringList mArgs; | |
96 | - int mFbFd; | |
97 | - int mTtyFd; | |
98 | -+ int mRotation; | |
99 | - | |
100 | - QImage mFbScreenImage; | |
101 | - int mBytesPerLine; | |
102 | - |
buildroot/buildroot-2016.08.1/package/qt5/qt5base/0008-linuxfb-rotation.patch
... | ... | @@ -0,0 +1,102 @@ |
1 | +diff --git a/src/plugins/platforms/linuxfb/qlinuxfbscreen.cpp b/src/plugins/platforms/linuxfb/qlinuxfbscreen.cpp | |
2 | +--- a/src/plugins/platforms/linuxfb/qlinuxfbscreen.cpp 2017-03-06 15:43:16.205457343 +0900 | |
3 | ++++ b/src/plugins/platforms/linuxfb/qlinuxfbscreen.cpp 2017-03-06 13:38:20.857076470 +0900 | |
4 | +@@ -280,7 +280,7 @@ | |
5 | + } | |
6 | + | |
7 | + QLinuxFbScreen::QLinuxFbScreen(const QStringList &args) | |
8 | +- : mArgs(args), mFbFd(-1), mTtyFd(-1), mBlitter(0) | |
9 | ++ : mArgs(args), mFbFd(-1), mTtyFd(-1), mBlitter(0), mRotation(0) | |
10 | + { | |
11 | + mMmap.data = 0; | |
12 | + } | |
13 | +@@ -306,6 +306,7 @@ | |
14 | + QRegularExpression mmSizeRx(QLatin1String("mmsize=(\\d+)x(\\d+)")); | |
15 | + QRegularExpression sizeRx(QLatin1String("size=(\\d+)x(\\d+)")); | |
16 | + QRegularExpression offsetRx(QLatin1String("offset=(\\d+)x(\\d+)")); | |
17 | ++ QRegularExpression rotationRx(QLatin1String("rotation=(0|90|180|270)")); | |
18 | + | |
19 | + QString fbDevice, ttyDevice; | |
20 | + QSize userMmSize; | |
21 | +@@ -327,6 +328,8 @@ | |
22 | + ttyDevice = match.captured(1); | |
23 | + else if (arg.contains(fbRx, &match)) | |
24 | + fbDevice = match.captured(1); | |
25 | ++ else if (arg.contains(rotationRx, &match)) | |
26 | ++ mRotation = match.captured(1).toInt(); | |
27 | + } | |
28 | + | |
29 | + if (fbDevice.isEmpty()) { | |
30 | +@@ -365,9 +368,17 @@ | |
31 | + mDepth = determineDepth(vinfo); | |
32 | + mBytesPerLine = finfo.line_length; | |
33 | + QRect geometry = determineGeometry(vinfo, userGeometry); | |
34 | ++ QRect originalGeometry = geometry; | |
35 | ++ if( mRotation == 90 || mRotation == 270 ) | |
36 | ++ { | |
37 | ++ int tmp = geometry.width(); | |
38 | ++ geometry.setWidth(geometry.height()); | |
39 | ++ geometry.setHeight(tmp); | |
40 | ++ } | |
41 | ++ | |
42 | + mGeometry = QRect(QPoint(0, 0), geometry.size()); | |
43 | + mFormat = determineFormat(vinfo, mDepth); | |
44 | +- mPhysicalSize = determinePhysicalSize(vinfo, userMmSize, geometry.size()); | |
45 | ++ mPhysicalSize = determinePhysicalSize(vinfo, userMmSize, originalGeometry.size()); | |
46 | + | |
47 | + // mmap the framebuffer | |
48 | + mMmap.size = finfo.smem_len; | |
49 | +@@ -377,11 +388,11 @@ | |
50 | + return false; | |
51 | + } | |
52 | + | |
53 | +- mMmap.offset = geometry.y() * mBytesPerLine + geometry.x() * mDepth / 8; | |
54 | ++ mMmap.offset = originalGeometry.y() * mBytesPerLine + originalGeometry.x() * mDepth / 8; | |
55 | + mMmap.data = data + mMmap.offset; | |
56 | + | |
57 | + QFbScreen::initializeCompositor(); | |
58 | +- mFbScreenImage = QImage(mMmap.data, geometry.width(), geometry.height(), mBytesPerLine, mFormat); | |
59 | ++ mFbScreenImage = QImage(mMmap.data, originalGeometry.width(), originalGeometry.height(), mBytesPerLine, mFormat); | |
60 | + | |
61 | + mCursor = new QFbCursor(this); | |
62 | + | |
63 | +@@ -409,8 +420,27 @@ | |
64 | + mBlitter->setCompositionMode(QPainter::CompositionMode_Source); | |
65 | + | |
66 | + for (int i = 0; i < rects.size(); ++i) | |
67 | ++ { | |
68 | ++ if( mRotation == 90 || mRotation == 270 ) | |
69 | ++ { | |
70 | ++ mBlitter->translate(mGeometry.height()/2, mGeometry.width()/2); | |
71 | ++ } | |
72 | ++ else if( mRotation == 180 ) | |
73 | ++ { | |
74 | ++ mBlitter->translate(mGeometry.width()/2, mGeometry.height()/2); | |
75 | ++ } | |
76 | ++ | |
77 | ++ if( mRotation != 0 ) | |
78 | ++ { | |
79 | ++ mBlitter->rotate(mRotation); | |
80 | ++ mBlitter->translate(-mGeometry.width()/2, -mGeometry.height()/2); | |
81 | ++ } | |
82 | ++ | |
83 | + mBlitter->drawImage(rects[i], *mScreenImage, rects[i]); | |
84 | + | |
85 | ++ mBlitter->resetTransform(); | |
86 | ++ } | |
87 | ++ | |
88 | + return touched; | |
89 | + } | |
90 | + | |
91 | +diff --git a/src/plugins/platforms/linuxfb/qlinuxfbscreen.h b/src/plugins/platforms/linuxfb/qlinuxfbscreen.h | |
92 | +--- a/src/plugins/platforms/linuxfb/qlinuxfbscreen.h 2016-05-26 00:46:17.000000000 +0900 | |
93 | ++++ b/src/plugins/platforms/linuxfb/qlinuxfbscreen.h 2017-03-06 13:38:20.857076470 +0900 | |
94 | +@@ -58,6 +58,7 @@ | |
95 | + QStringList mArgs; | |
96 | + int mFbFd; | |
97 | + int mTtyFd; | |
98 | ++ int mRotation; | |
99 | + | |
100 | + QImage mFbScreenImage; | |
101 | + int mBytesPerLine; | |
102 | + | ... | ... |
env-4.9.4.env
kernel/linux-imx6_3.14.28/drivers/mtd/spi-nor/spi-nor.c
... | ... | @@ -472,6 +472,10 @@ const struct spi_device_id spi_nor_ids[] = { |
472 | 472 | { "mr25h256", CAT25_INFO( 32 * 1024, 1, 256, 2, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) }, |
473 | 473 | { "mr25h10", CAT25_INFO(128 * 1024, 1, 256, 3, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) }, |
474 | 474 | |
475 | + /* Fujitsu */ | |
476 | + { "mb85rs16", INFO(0x047f01, 0, 2 * 1024, 1, SPI_NOR_NO_ERASE) }, | |
477 | + { "mb85rs1mt", INFO(0x047f27, 0, 128 * 1024, 1, SPI_NOR_NO_ERASE) }, | |
478 | + | |
475 | 479 | /* GigaDevice */ |
476 | 480 | { "gd25q32", INFO(0xc84016, 0, 64 * 1024, 64, SECT_4K) }, |
477 | 481 | { "gd25q64", INFO(0xc84017, 0, 64 * 1024, 128, SECT_4K) }, | ... | ... |