Linux第99步_Linux之点亮LCD

主要学习如何在Linux开发板点亮屏,以及modetest命令的实现。

很多人踩坑,我也是一样。关键是踩坑后还是实现不了,这样的人确实很多,从群里可以知道。也许其他人没有遇到这个问题,我想是他运气好。

1、修改设备树

1)、打开"stm32mp15-pinctrl.dtsi",找到"ltdc_pins_b"节点和"ltdc_pins_sleep_b"节点,如下:

ltdc_pins_b: ltdc-b-0 {

pins {

pinmux = <STM32_PINMUX('I', 14, AF14)>, /* LCD_CLK */

<STM32_PINMUX('I', 12, AF14)>, /* LCD_HSYNC */

<STM32_PINMUX('I', 13, AF14)>, /* LCD_VSYNC */

<STM32_PINMUX('K', 7, AF14)>, /* LCD_DE */

<STM32_PINMUX('I', 15, AF14)>, /* LCD_R0 */

<STM32_PINMUX('J', 0, AF14)>, /* LCD_R1 */

<STM32_PINMUX('J', 1, AF14)>, /* LCD_R2 */

<STM32_PINMUX('J', 2, AF14)>, /* LCD_R3 */

<STM32_PINMUX('J', 3, AF14)>, /* LCD_R4 */

<STM32_PINMUX('J', 4, AF14)>, /* LCD_R5 */

<STM32_PINMUX('J', 5, AF14)>, /* LCD_R6 */

<STM32_PINMUX('J', 6, AF14)>, /* LCD_R7 */

<STM32_PINMUX('J', 7, AF14)>, /* LCD_G0 */

<STM32_PINMUX('J', 8, AF14)>, /* LCD_G1 */

<STM32_PINMUX('J', 9, AF14)>, /* LCD_G2 */

<STM32_PINMUX('J', 10, AF14)>, /* LCD_G3 */

<STM32_PINMUX('J', 11, AF14)>, /* LCD_G4 */

<STM32_PINMUX('K', 0, AF14)>, /* LCD_G5 */

<STM32_PINMUX('K', 1, AF14)>, /* LCD_G6 */

<STM32_PINMUX('K', 2, AF14)>, /* LCD_G7 */

<STM32_PINMUX('J', 12, AF14)>, /* LCD_B0 */

<STM32_PINMUX('J', 13, AF14)>, /* LCD_B1 */

<STM32_PINMUX('J', 14, AF14)>, /* LCD_B2 */

<STM32_PINMUX('J', 15, AF14)>, /* LCD_B3 */

<STM32_PINMUX('K', 3, AF14)>, /* LCD_B4 */

<STM32_PINMUX('K', 4, AF14)>, /* LCD_B5 */

<STM32_PINMUX('K', 5, AF14)>, /* LCD_B6 */

<STM32_PINMUX('K', 6, AF14)>; /* LCD_B7 */

bias-disable;/*禁止使用内部偏置电压*/

drive-push-pull;/*设置引脚为推挽输出*/

slew-rate = <1>;/*设置引脚的速度为1档,0最慢,3 最高*/

};

ltdc_pins_sleep_b: ltdc-b-1 {/*在sleep模式下RGB LCD的pinmux配置*/

pins {

pinmux = <STM32_PINMUX('I', 14, ANALOG)>, /* LCD_CLK */

<STM32_PINMUX('I', 12, ANALOG)>, /* LCD_HSYNC */

<STM32_PINMUX('I', 13, ANALOG)>, /* LCD_VSYNC */

<STM32_PINMUX('K', 7, ANALOG)>, /* LCD_DE */

<STM32_PINMUX('I', 15, ANALOG)>, /* LCD_R0 */

<STM32_PINMUX('J', 0, ANALOG)>, /* LCD_R1 */

<STM32_PINMUX('J', 1, ANALOG)>, /* LCD_R2 */

<STM32_PINMUX('J', 2, ANALOG)>, /* LCD_R3 */

<STM32_PINMUX('J', 3, ANALOG)>, /* LCD_R4 */

<STM32_PINMUX('J', 4, ANALOG)>, /* LCD_R5 */

<STM32_PINMUX('J', 5, ANALOG)>, /* LCD_R6 */

<STM32_PINMUX('J', 6, ANALOG)>, /* LCD_R7 */

<STM32_PINMUX('J', 7, ANALOG)>, /* LCD_G0 */

<STM32_PINMUX('J', 8, ANALOG)>, /* LCD_G1 */

<STM32_PINMUX('J', 9, ANALOG)>, /* LCD_G2 */

<STM32_PINMUX('J', 10, ANALOG)>, /* LCD_G3 */

<STM32_PINMUX('J', 11, ANALOG)>, /* LCD_G4 */

<STM32_PINMUX('K', 0, ANALOG)>, /* LCD_G5 */

<STM32_PINMUX('K', 1, ANALOG)>, /* LCD_G6 */

<STM32_PINMUX('K', 2, ANALOG)>, /* LCD_G7 */

<STM32_PINMUX('J', 12, ANALOG)>, /* LCD_B0 */

<STM32_PINMUX('J', 13, ANALOG)>, /* LCD_B1 */

<STM32_PINMUX('J', 14, ANALOG)>, /* LCD_B2 */

<STM32_PINMUX('J', 15, ANALOG)>, /* LCD_B3 */

<STM32_PINMUX('K', 3, ANALOG)>, /* LCD_B4 */

<STM32_PINMUX('K', 4, ANALOG)>, /* LCD_B5 */

<STM32_PINMUX('K', 5, ANALOG)>, /* LCD_B6 */

<STM32_PINMUX('K', 6, ANALOG)>; /* LCD_B7 */

};

上面的连接和原理图一致,不用修改。

2)、检查是否有被使用的引脚:

PI12被hdp0_pins_a节点占用,要屏蔽,见下图:

3)、打开"stm32mp157d-atk.dts",添加内容如下(注意:不是在根节点"/"下添加):

ltdc {

pinctrl-names = "default", "sleep";

pinctrl-0 = <<dc_pins_b>;/*pinctrl-0为default模式*/

pinctrl-1 = <<dc_pins_sleep_b>;/*pinctrl-1为sleep模式*/

/*设置了两个pinmux模式:pinctrl-0为default模式,pinctrl-1为sleep模式,

系统默认使用default模式。*/

status = "okay";

port {

#address-cells = <1>;

#size-cells = <0>;

ltdc_ep0_out: endpoint@0 {/*ltdc_ep0_out为port的子节点*/

reg = <0>;

remote-endpoint = <&rgb_panel_in>;

/*remote-endpoint属性告诉ltdc节点输出到rgb_panel_in接口*/

};

};

};

4)、在stm32mp157d-atk.dts文件的根节点"/"下,添加"输出接口"如下所示内容:

panel_rgb: panel-rgb {

compatible = "zgq,lcd-rgb";

/*在 panel-simple.c 文件里的platform_of_match数组增加一个

of_device_id结构体,此结构体的compatible成员属性值为"zgq,lcd-rgb"。*/

backlight = <&backlight>;/*此属性值为引用背光节点*/

status = "okay";

port {

rgb_panel_in: endpoint {

remote-endpoint = <<dc_ep0_out>;

/*要从ltdc节点里获取显示数据*/

};

};

};

2、修改"panel-simple.c"程序

1)、打开"panel-simple.c",修改platform_of_match[]数组,添加内容如下:

{

.compatible = "zgq,lcd-rgb",

.data = &zgq_desc,

}

2)、在"panel-simple.c"中添加"zgq_desc"参数。

我用的是ATK4384,4.3寸800*480分辨率,参数如下:

/* LCD屏ATK4384的时序参数信息需要向厂家要:4.3寸800*480分辨率 */

static const struct drm_display_mode ATK4384_mode = {

.clock = 31000, /* LCD像素时钟,单位KHz */

.hdisplay = 800, /* LCD X轴像素个数 */

.hsync_start = 800 + 88, /* LCD X轴+hbp的像素个数 */

.hsync_end = 800 + 88 + 48, /* LCD X轴+hbp+hspw的像素个数 */

.htotal = 800 + 88 + 48 + 40,/* LCD X轴+hbp+hspw+hfp */

.vdisplay = 480, /* LCD Y轴像素个数 */

.vsync_start = 480 + 32, /* LCD Y轴+vbp的像素个数 */

.vsync_end = 480 + 32 + 3, /* LCD Y轴+vbp+vspw的像素个数 */

.vtotal = 480 + 32 + 3 + 13,/* LCD Y轴+vbp+vspw+vfp */

.vrefresh = 60, /* LCD的刷新频率为60HZ */

};

static const struct panel_desc zgq_desc = {

.modes = &ATK4384_mode,

.num_modes = 1,

.bus_format = MEDIA_BUS_FMT_RGB888_1X24,

};

3、再次修改设备树头文件,在"stm32mp15-pinctrl.dtsi"中添加"背光节点"

1)、打开"stm32mp15-pinctrl.dtsi",找到"pwm4_pins_b",内容如下:

pwm4_pins_b: pwm4-1 {

pins {

pinmux = <STM32_PINMUX('D', 13, AF2)>; /* TIM4_CH2 */

bias-pull-down;

drive-push-pull;

slew-rate = <0>;

};

};

pwm4_sleep_pins_b: pwm4-sleep-1 {

pins {

pinmux = <STM32_PINMUX('D', 13, ANALOG)>; /* TIM4_CH2 */

};

};

2)、在"stm32mp157d-atk.dts"文件里,添加"&timers4"如下所示内容:

&timers4 {

status = "okay";

/* spare dmas for other usage */

/delete-property/dmas;/*设置此节点不使用DMA*/

/delete-property/dma-names;/*设置此节点不使用DMA*/

pwm4: pwm {/*pwm4是我们为pwm设置的一个别名。*/

pinctrl-0 = <&pwm4_pins_b>;/*设置PWM所使用的IO配置*/

pinctrl-1 = <&pwm4_sleep_pins_b>;/*设置PWM所使用的IO配置*/

pinctrl-names = "default", "sleep";

#pwm-cells = <2>;

status = "okay";

};

};

3)、修改设备树文件,在stm32mp157d-atk.dts文件里,在根节点里,添加"backlight"节点:

backlight: backlight {

compatible = "pwm-backlight";

pwms = <&pwm4 1 5000000>;

/*设置背光使用pwm4的第2个通道,PWM频率为1000000000/5000000=200Hz*/

brightness-levels = <0 4 8 16 32 64 128 255>;

/*设置背 8 级背光(0~7),分别为 0、4、8、16、32、64、128、255,

对应占空比为 0%、1.57%、3.13%、6.27%、12.55%、25.1%、50.19%、100%*/

power-supply = <&v3v3>;

default-brightness-level = <7>;

/*设置默认背光等级为7,也就是100%的亮度*/

status = "okay";

};

4)、修改"pwm_bl.c"文件

因为背光的驱动代码有点bug,如果设置0级,屏不会灭屏,打开pwm_bl.c文件,将下面的代码修改一下:

if (brightness > 0) {

pwm_get_state(pb->pwm, &state);

state.duty_cycle = compute_duty_cycle(pb, brightness);

pwm_apply_state(pb->pwm, &state);

pwm_backlight_power_on(pb);

}

改成如下:

if (brightness >= 0) {

pwm_get_state(pb->pwm, &state);

state.duty_cycle = compute_duty_cycle(pb, brightness);

pwm_apply_state(pb->pwm, &state);

pwm_backlight_power_on(pb);

}

见下图:

4、配置"Linux内核"

1)、打开终端。

2)、输入"cd linux/atk-mp1/linux/my_linux/linux-5.4.31/回车",切换到"linux/atk-mp1/linux/my_linux/linux-5.4.31/"目录;

3)、输入"make menuconfig回车",打开linux内核图形化配置界面:

4)、移动"向下光标键"至"Device Drivers",见下图:

5)、按下"回车键",移动"向下光标键"至"Graphics support",见下图:

6)、按下"回车键",移动"向下光标键"至"Direct Rendering Manager (XFree86 4.1.0 and higher DRI suppor",按"Y键",见下图:

7)、移动"向下光标键"至"DRM Support for Samsung SoC EXYNOS Series",按"Y键",见下图:

8)、先"保存",按"TAB键"至"Save",按下"回车键",得到下面的界面。

9)、输入"./arch/arm/configs/stm32mp1_atk_defconfig",移动"向下光标键"至"Ok",得到下图:

10)、按"回车键",保存完成。得到下面的界面。

11)、按"回车键",退出保存界面。

12)、移动"向下光标键"至"Display Panels",见下图:

13)、按"回车键",移动"向下光标键"至"support for simple panels",按"Y键",见下图:

14)、按一下"TAB键"至"Exit"。注意:最好也保存一下,防止配置软件有bug。见下图:

15)、按"回车键",移动"向下光标键"至"Backlight & LCD device support",见下图:

16)、按"回车键",移动"向下光标键"至"Generic PWM based Backlight Driver",按下"Y键",见下图:

17)、按"TAB键"至"Save",按下"回车",得到下面的界面。

18)、输入"./arch/arm/configs/stm32mp1_atk_defconfig",移动"向下光标键"至"Ok",得到下图:

19)、按"回车",保存完成。得到下面的界面。

20)、按"回车键",退出。

21)、按8次"ESC键",得到下图:

22)、输入"make stm32mp1_atk_defconfig回车"。

注意:图形化配置完后,要在终端输入"make stm32mp1_atk_defconfig回车",更新".config"这个文件,才叫图形化配置完成,因为参与编译的文件是".config"这个文件。我编译成功,完全是巧合。

5、编译设备树

①在VSCode终端,输入"make uImage dtbs LOADADDR=0XC2000040 -j8回车",执行编译"Image"和"dtbs",并指定装载的起始地址为0XC2000040,j8表示指定采用8线程执行。"make dtbs",用来指定编译设备树。

②输入"ls arch/arm/boot/uImage -l"

查看是否生成了新的"uImage"文件

③输入"ls arch/arm/boot/dts/stm32mp157d-atk.dtb -l"

查看是否生成了新的"stm32mp157d-atk.dtb"文件

4)、拷贝输出的文件:

①输入"cp arch/arm/boot/uImage /home/zgq/linux/atk-mp1/linux/bootfs/ -f回车",执行文件拷贝,准备烧录到EMMC;

②输入"cp arch/arm/boot/dts/stm32mp157d-atk.dtb /home/zgq/linux/atk-mp1/linux/bootfs/ -f回车",执行文件拷贝,准备烧录到EMMC

③输入"cp arch/arm/boot/uImage /home/zgq/linux/tftpboot/ -f回车",执行文件拷贝,准备从tftp下载;

④输入"cp arch/arm/boot/dts/stm32mp157d-atk.dtb /home/zgq/linux/tftpboot/ -f回车",执行文件拷贝,准备从tftp下载;

⑤输入"ls -l /home/zgq/linux/atk-mp1/linux/bootfs/回车",查看"/home/zgq/linux/atk-mp1/linux/bootfs/"目录下的所有文件和文件夹

⑥输入"ls -l /home/zgq/linux/tftpboot/回车",查看"/home/zgq/linux/tftpboot/"目录下的所有文件和文件夹

⑦输入"chmod 777 /home/zgq/linux/tftpboot/stm32mp157d-atk.dtb回车"

给"stm32mp157d-atk.dtb"文件赋予可执行权限

⑧输入"chmod 777 /home/zgq/linux/tftpboot/uImage回车" ,给"uImage"文件赋予可执行权限

⑨输入"ls /home/zgq/linux/tftpboot/ -l回车",查看"/home/zgq/linux/tftpboot/"目录下的所有文件和文件夹

6、文件系统使能libdrm库

如果没有libdrm库,是不能调用drm驱动的,所以我们要在文件系统中使能libdrm库。

1)、输入"cd /home/zgq/linux/buildroot/buildroot-2020.02.6回车"

2)、输入"make menuconfig回车",打开"buildroot的图形化配置界面"

3)、移动"向下光标键"至"Target packages",见下图:

4)、按"回车键",移动"向下光标键"至"Libraries",见下图:

5)、按"回车键",移动"向下光标键"至"Graphics",见下图:

6)、按"回车键",移动"向下光标键"至"libdrm",按下"Y键",见下图:

7)、按"TAB键",移动"向右光标键"至"Save",按"回车键"。

注意:这里必须要先保存,否则一次性保存会失败,我试过了,不要踩坑。

8)、将"/zgq/linux/buildroot/buildroot-2020.02.6/.config"修改为

"./configs/stm32mp1_atk_defconfig",见下图:

9)、移动"向下光标键"至"Ok",按"回车键";按"ESC"

10)、按下"回车键",移动"向下光标键"至"Install test programs",按下"Y键",见下图:

11)、按"TAB键",移动光标至"Save",按"回车键"

12)、将"/zgq/linux/buildroot/buildroot-2020.02.6/.config"修改为

"./configs/stm32mp1_atk_defconfig",见下图:

13)、移动"向下光标键"至"Ok",按"回车键"完成保存;

这里,我们将配置项命名为"stm32mp1_atk_defconfig",以后要重新配置buildroot的话,就可以直接输入"make stm32mp1_atk_defconfig回车"。

15)、按"ESC键"退出,直到出现下图:

16)、输入"make stm32mp1_atk_defconfig回车"

注意:图形化配置完后,要在终端输入"make stm32mp1_atk_defconfig回车",更新".config"这个文件,才叫图形化配置完成,因为参与编译的文件是".config"这个文件。我编译成功,完全是巧合。可以这么理解"stm32mp1_atk_defconfig"好比是缓存,而".config"才是我们要修改的文件。

7、编译"buildroot"

1)、在"/home/zgq/linux/buildroot/buildroot-2020.02.6"目录,

输入"make -j8",编译"buildroot",-j8表示采用8线程编译

2)、等待下载"host-python3 3.8.5"见下图:

3)、等待下载"host-python3-setuptools 41.4.0"

4)、查看编译结果:

输入"cd output/"切换到"output"目录

输入"ls",查看"output"目录下的所有文件和文件夹

输入"cd images/"切换到"images"目录

输入"ls",查看"images"目录下的所有文件和文件夹

5)、打开第2个终端

输入"cd linux/nfs/rootfs",切换到"linux/nfs/rootfs"目录

输入"ls回车"

输入"sudo rm * -rf回车",删除"rootfs"目录下所有的文件和文件夹,前面已经做了备份

输入"ls回车"

输入"cd ..回车",返回到"nfs"目录

输入"ls回车"

6)、回到第1个打开的终端

输入"cp rootfs.tar /home/zgq/linux/nfs/rootfs回车"

将"/home/zgq/linux/buildroot/buildroot-2020.02.6/output/images"目录下的"rootfs.tar"拷贝到"/home/zgq/linux/nfs/rootfs"目录中

7)、回到第2个打开的终端

输入"cd rootfs/回车"

输入"ls回车"

输入"sudo tar -axvf rootfs.tar",解压

8)、输入"ls回车"

输入"rm rootfs.tar回车",删除压缩包

输入"ls回车"

得到buildroot生成的根文件系统。

8、使用****"buildroot"构建根文件系统****

1)、给开发板上电。

输入"root回车"

输入密码"123456回车"

输入"cd /",切换到根目录

输入"ls",可以执行了

2)、输入"reboot回车"

输入"root回车"

输入"depmod回车",报告"depmod: can't change directory to 'lib/modules/5.4.31': No such file or directory"

输入"mkdir /lib/modules/5.4.31 -p回车"

输入"depmod回车"

输入"cd /lib/modules/5.4.31回车"

输入"ls回车"

9、使用vsftpd搭建FTP服务器

1)、输入"vi /etc/vsftpd.conf回车"

按"ESC键",输入"/local_enable=回车",搜索字符串"local_enable="

,先按下"A",然后移动光标至"#local_enable=YES",删除"#",修改为"local_enable=YES"

按"ESC键",输入"/write_enable=回车",搜索字符串"write_enable="

,先按下"A",然后移动光标至"#write_enable=YES",删除"#",修改为"write_enable=YES"

2)、按"ESC键",输入":wq回车",保存退出。

10、测试:使用SSH服务通过网络远程登录开发板

1)、输入"ls /etc/vsftpd.conf -l回车"

报告"-rw-r--r-- 1 sshd sshd 4591 Feb 17 2024 /etc/vsftpd.conf",表示该文件所属用户为"sshd";

输入"chown root:root /etc/vsftpd.conf回车",将/etc/vsftpd.conf修改为"root"用户。

输入"ls /etc/vsftpd.conf -l回车"

报告"-rw-r--r-- 1 root root 4591 Feb 17 2024 /etc/vsftpd.conf",表示该文件所属用户为"root";

2)、输入"adduser Zhanggong回车",使用adduser命令创建开发板用户名为Zhanggong

输入密码"123456"

输入密码"123456"

输入"cd /home/回车"

输入"ls回车"

3)、打开"FileZilla"

4)、点击"文件",再点击"站点管理器"

5)、点击"新站点",修改为"MP157开发板"

6)、等待开发板启动完成,输入"root回车",输入"ifconfig回车",查询卡发板的IP地址

7)、设置开发板的IP地址,用户名和密码

8)、在串口终端输入"reboot",重启开发板。

9)、等待开发板启动完成,再点击"连接"

10、在串口终端输入"root回车",输入"ps回车"

11)、输入"chown root:root /var/empty回车",将"/var/empty"修改为"root"用户。

输入"reboot回车",重启开发板

12)、等待开发板启动完成后,在串口终端输入"root回车",输入"ps回车"

13)、点击"sesson",点击"SSH",然后按照下图设置开发板:

14)、输入密码"123456"

输入"cd /回车",切换至根目录

输入"ls回车"

至此,我们完成了SSH测试。

11、创建"自启动文件"

1)、输入"cd /etc/init.d/",切换到"init.d"目录

输入"ls"

输入"touch Sautorun",创建Sautorun文件

输入"ls"

输入"chmod 777 Sautorun",给"Sautorun"赋可执行权限

输入"ls"

2)、输入"vi Sautorun回车"

先按"A",然后输入内容:

#!/bin/sh

cd /

按"ESC键",输入":wq回车"

12、设置开发板需要显示路径

1)、输入"vi /etc/profile回车"

按"ESC键",输入":q!回车",不保存退出。

输入"cd /etc/profile.d回车"

输入"ls回车"

输入"touch myprofile.sh",创建脚本文件"myprofile.sh"

输入"ls回车"

输入"chmod 777 myprofile.sh",给myprofile.sh赋可执行权限

输入"ls回车"

输入"vi myprofile.sh",打开myprofile.sh文件

先按"A",再输入内容如下

#!/bin/sh

PS1='[\u@\h]:\w$ ' #\u表示用户名,\h表示主机名,\w表示显示当前工作目录的路径

export PS1

2)、按"ESC键",输入":wq回车",保存退出。

3)、输入"reboot"重启开发板

等待开发板启动完成,输入"root回车"

输入"cd /回车"

输入"ls回车"

输入"cd etc/回车"

可以看到工作路径了。

13、使能"sysfs debug"目录

1)、输入"cd /sys/kernel/debug/"

输入"ls回车"

在"Sautorun"文件中,添加"mount -t debugfs none /sys/kernel/debug"

输入"vi /etc/init.d/Sautorun"

输入内容如下:

#!/bin/sh

mount -t debugfs none /sys/kernel/debug

4)、按"ESC键",输入":wq回车",保存退出。

输入"reboot"重启开发板

6)、等待开饭启动完成,输入"root回车"

输入"ls"

输入"ls /sys/kernel/debug/"

至此,根文件系统测试完成了。

7)、输入"modetest --help回车",发现可以执行"modetest --help"

14、点亮显示屏

1)、输入"modetest --help回车"

2)、输入"modetest -M stm回车"

输入"modetest -M stm回车"

输入"modetest -M stm -s 32@35:800x480回车"

具体显示内容如下:

Welcome to zgq STM32MP157

ATK-stm32mp1 login: root

[root@ATK-stm32mp1]:~$ modetest --help

usage: modetest [-acDdefMPpsCvw]

Query options:

-c list connectors

-e list encoders

-f list framebuffers

-p list CRTCs and planes (pipes)

Test options:

-P <plane_id>@<crtc_id>:<w>x<h>[+<x>+<y>][*<scale>][@<format>] set a plane

-s <connector_id>[,<connector_id>][@<crtc_id>]:<mode>[-<vrefresh>][@<format>] set a mode

-C test hw cursor

-v test vsynced page flipping

-w <obj_id>:<prop_name>:<value> set property

-a use atomic API

-F pattern1,pattern2 specify fill patterns

Generic options:

-d drop master after mode set

-M module use the given driver

-D device use the given device

Default is to dump all info.

[root@ATK-stm32mp1]:~$ modetest -M stm

Encoders:

id crtc type possible crtcs possible clones

31 0 DPI 0x00000001 0x00000000

Connectors:

id encoder status name size (mm) modes encoders

32 0 connected DPI-1 105x67 1 31

modes:

name refresh (Hz) hdisp hss hse htot vdisp vss vse vtot)

800x480 60 800 888 936 976 480 512 515 528 31000 flags: ; type: preferred, driver

props:

1 EDID:

flags: immutable blob

blobs:

value:

2 DPMS:

flags: enum

enums: On=0 Standby=1 Suspend=2 Off=3

value: 0

5 link-status:

flags: enum

enums: Good=0 Bad=1

value: 0

6 non-desktop:

flags: immutable range

values: 0 1

value: 0

4 TILE:

flags: immutable blob

blobs:

value:

20 CRTC_ID:

flags: object

value: 0

CRTCs:

id fb pos size

35 0 (0,0) (0x0)

0 0 0 0 0 0 0 0 0 0 flags: ; type:

props:

22 ACTIVE:

flags: range

values: 0 1

value: 0

23 MODE_ID:

flags: blob

blobs:

value:

19 OUT_FENCE_PTR:

flags: range

values: 0 18446744073709551615

value: 0

24 VRR_ENABLED:

flags: range

values: 0 1

value: 0

28 GAMMA_LUT:

flags: blob

blobs:

value:

29 GAMMA_LUT_SIZE:

flags: immutable range

values: 0 4294967295

value: 256

Planes:

id crtc fb CRTC x,y x,y gamma size possible crtcs

33 0 0 0,0 0,0 0 0x00000001

formats: AR24 XR24 RG24 RG16 AR15 XR15 AR12 XR12 C8

props:

8 type:

flags: immutable enum

enums: Overlay=0 Primary=1 Cursor=2

value: 1

17 FB_ID:

flags: object

value: 0

18 IN_FENCE_FD:

flags: signed range

values: -1 2147483647

value: -1

20 CRTC_ID:

flags: object

value: 0

13 CRTC_X:

flags: signed range

values: -2147483648 2147483647

value: 0

14 CRTC_Y:

flags: signed range

values: -2147483648 2147483647

value: 0

15 CRTC_W:

flags: range

values: 0 2147483647

value: 0

16 CRTC_H:

flags: range

values: 0 2147483647

value: 0

9 SRC_X:

flags: range

values: 0 4294967295

value: 0

10 SRC_Y:

flags: range

values: 0 4294967295

value: 0

11 SRC_W:

flags: range

values: 0 4294967295

value: 0

12 SRC_H:

flags: range

values: 0 4294967295

value: 0

30 IN_FORMATS:

flags: immutable blob

blobs:

value:

01000000000000000900000018000000

01000000400000004152323458523234

52473234524731364152313558523135

41523132585231324338202000000000

ff010000000000000000000000000000

0000000000000000

in_formats blob decoded:

AR24: LINEAR

XR24: LINEAR

RG24: LINEAR

RG16: LINEAR

AR15: LINEAR

XR15: LINEAR

AR12: LINEAR

XR12: LINEAR

C8 : LINEAR

36 0 0 0,0 0,0 0 0x00000001

formats: AR24 RG24 RG16 AR15 AR12 C8

props:

8 type:

flags: immutable enum

enums: Overlay=0 Primary=1 Cursor=2

value: 0

17 FB_ID:

flags: object

value: 0

18 IN_FENCE_FD:

flags: signed range

values: -1 2147483647

value: -1

20 CRTC_ID:

flags: object

value: 0

13 CRTC_X:

flags: signed range

values: -2147483648 2147483647

value: 0

14 CRTC_Y:

flags: signed range

values: -2147483648 2147483647

value: 0

15 CRTC_W:

flags: range

values: 0 2147483647

value: 0

16 CRTC_H:

flags: range

values: 0 2147483647

value: 0

9 SRC_X:

flags: range

values: 0 4294967295

value: 0

10 SRC_Y:

flags: range

values: 0 4294967295

value: 0

11 SRC_W:

flags: range

values: 0 4294967295

value: 0

12 SRC_H:

flags: range

values: 0 4294967295

value: 0

30 IN_FORMATS:

flags: immutable blob

blobs:

value:

01000000000000000600000018000000

01000000300000004152323452473234

52473136415231354152313243382020

3f000000000000000000000000000000

0000000000000000

in_formats blob decoded:

AR24: LINEAR

RG24: LINEAR

RG16: LINEAR

AR15: LINEAR

AR12: LINEAR

C8 : LINEAR

Frame buffers:

id size pitch

[root@ATK-stm32mp1]:~$ modetest -M stm -s 32@35:800x480

setting mode 800x480-60Hz@XR24 on connectors 32, crtc 35

相关推荐
打不了嗝 ᥬ᭄1 小时前
Linux的权限
linux
落幕1 小时前
C语言-进程
linux·运维·服务器
深度Linux2 小时前
C++程序员内功修炼——Linux C/C++编程技术汇总
linux·项目实战·c/c++
风静如云3 小时前
OpenBMC:BmcWeb定义service
linux
leoufung3 小时前
VIM FZF 安裝和使用
linux·编辑器·vim
bugtraq20214 小时前
XiaoMi Mi5(gemini) 刷入Ubuntu Touch 16.04——安卓手机刷入Linux
linux·运维·ubuntu
CodeWithMe5 小时前
[ Vim ] 常用命令 and 配置
linux·编辑器·vim
DC_BLOG5 小时前
Linux-GlusterFS进阶分布式卷
linux·运维·服务器·分布式
cookies_s_s6 小时前
Linux--进程(进程虚拟地址空间、页表、进程控制、实现简易shell)
linux·运维·服务器·数据结构·c++·算法·哈希算法
丁劲犇6 小时前
碳基生物的悲歌-DeepSeek思考实现Linux动态库递归收集工具
linux·递归·deepseek·ldd