首页 > 技术知识 > 正文

USB鼠标插入USB2不供电问题解决

①增加 IO 控制驱动

解压 IO 控制驱动压缩包:

io_zhouke.tar.gz 复制压缩包的文件到 drivers/char/ 目录下: tarzxvfio_zhouke.tar.gz cpio_zhouke/*drivers/char/-avf 注释:这些文件可以在 3.1 LTS 版本中获取,复制完之后 drivers/char 目录结构如下。 -rw-rw-r–11000100013KDec1308:13id_card.cio:total28K-rw-rw-r–11000100044Jul1209:52Makefile-rw-rw-r–110001000138Dec1308:02built-in.a-rw-rw-r–1100010000Aug1706:41modules.order-rw-rw-r–1100010007.9KJul1209:52io.c-rw-rw-r–1100010002.6KJul1209:52io.h-rw-rw-r–1100010002.0KJul1209:52io_external.c-rw-rw-r–1100010004.0KJul1209:52io_stub.c 相应的修改Makefile文件,把驱动编译到内核中 drivers/char/Makefile #SPDX-License-Identifier:GPL-2.0# #Makefileforthekernelcharacterdevicedrivers.# obj-y+=jy.o obj-y+=mcu.o +obj-y+=io///增加此行obj-y+=mem.orandom.o obj-$(CONFIG_TTY_PRINTK)+=ttyprintk.oobj-y+=misc.o obj-$(CONFIG_ATARI_DSP56K)+=dsp56k.o obj-$(CONFIG_VIRTIO_CONSOLE)+=virtio_console.oobj-$(CONFIG_RAW_DRIVER)+=raw.o obj-$(CONFIG_MSPEC)+=mspec.o obj-$(CONFIG_UV_MMTIMER)+=uv_mmtimer.oobj-$(CONFIG_IBM_BSR)+=bsr.o obj-$(CONFIG_PRINTER)+=lp.o obj-$(CONFIG_APM_EMULATION)+=apm-emulation.oobj-$(CONFIG_DTLK)+=dtlk.o obj-$(CONFIG_APPLICOM)+=applicom.o obj-$(CONFIG_SONYPI)+=sonypi.o obj-$(CONFIG_HPET)+=hpet.o obj-$(CONFIG_XILINX_HWICAP)+=xilinx_hwicap/obj-$(CONFIG_NVRAM)+=nvram.o obj-$(CONFIG_TOSHIBA)+=toshiba.o obj-$(CONFIG_DS1620)+=ds1620.o obj-$(CONFIG_HW_RANDOM)+=hw_random/obj-$(CONFIG_PPDEV)+=ppdev.o obj-$(CONFIG_NWBUTTON)+=nwbutton.o obj-$(CONFIG_NWFLASH)+=nwflash.o obj-$(CONFIG_SCx200_GPIO)+=scx200_gpio.oobj-$(CONFIG_PC8736x_GPIO)+=pc8736x_gpio.oobj-$(CONFIG_NSC_GPIO)+=nsc_gpio.o obj-$(CONFIG_GPIO_TB0219)+=tb0219.o obj-$(CONFIG_TELCLOCK)+=tlclk.o obj-$(CONFIG_MWAVE)+=mwave/ obj-y+=agp/ obj-$(CONFIG_PCMCIA)+=pcmcia/ obj-$(CONFIG_HANGCHECK_TIMER)+=hangcheck-timer.oobj-$(CONFIG_TCG_TPM)+=tpm/ obj-$(CONFIG_PS3_FLASH)+=ps3flash.oobj-$(CONFIG_XILLYBUS)+=xillybus/ obj-$(CONFIG_POWERNV_OP_PANEL)+=powernv-op-panel.oobj-$(CONFIG_ADI)+=adi.o

②增加 USB 相关支持

修改 arch/arm64/configs/rockchip_linux_defconfig:

CONFIG_USB_ACM=yCONFIG_USB_SERIAL_QT2=y 重新编译内核,此时 USB 可以正确识别鼠标生成对应的设备节点,但是鼠标还是不能正常工作。

内核崩溃问题解决

内核崩溃 log 如下:

[61.187709]kernelBUGatkernel/sched/walt.h:108![61.188143]Internalerror:Oops-BUG:0[#1]SMP[61.188573]Moduleslinkedin: [61.188866]CPU:3PID:25Comm:migration/3Tainted:GW5.10.97#6[61.189541]Hardwarename:RockchipRK3399ExcavatorBoard(LinuxOpensource)(DT)[61.190214]pstate:80000085(NzcvdaIf-PAN-UAO-TCOBTYPE=–) [61.190760]pc:dequeue_task_rt+0xf8/0xfc[61.191131]lr:dequeue_task_rt+0x68/0xfc[61.191497]sp:ffffffc011bd3ce0 [61.191797]x29:ffffffc011bd3ce0x28:0000000000000000[61.192281]x27:0000000000000000×26:0000000000000001[61.192765]x25:ffffffc011854000x24:ffffff800245cb00[61.193247]x23:ffffff80f779e440x22:ffffff800c799180[61.193729]x21:0000000000000000×20:ffffff800c798f00[61.194211]x19:ffffff80f779e440x18:00000000ffff1020[61.194693]x17:0000000000000000×16:00000000000000e0[61.195176]x15:ffffffc010645160x14:000000000000006c[61.195658]x13:ffffffc0100a2f8cx12:0000000000000000[61.196140]x11:0000000000000001×10:ffffffc010f7be28[61.196622]x9:0000000000000002×8:ffffffffffffffd8[61.197104]x7:6e6f636e69203a69x6:ffffffc011908110[61.197586]x5:0000000000000004×4:0000000000000001[61.198067]x3:0000000000000000×2:0000000000000000[61.198550]x1:0000000000000000×0:ffffff80f779e800[61.199034]Calltrace:[61.199264]dequeue_task_rt+0xf8/0xfc[61.199608]dequeue_task+0xbc/0x2c4[61.199935]deactivate_task+0x28/0x34[61.200278]rt_active_load_balance_cpu_stop+0x90/0x150[61.200749]cpu_stopper_thread+0xac/0x154[61.201119]smpboot_thread_fn+0x100/0x190[61.201491]kthread+0x11c/0x174[61.201787]ret_from_fork+0x10/0x30[61.202117]Code:f9400bf7a8c47bfdd50323bfd65f03c0(d4210000)[61.202662]—[endtrace72c26b1564636cfc]—[61.203076]Kernelpanic-notsyncing:Oops-BUG:Fatalexception[61.203639]SMP:stoppingsecondaryCPUs[62.370663]SMP:failedtostopsecondaryCPUs1,3-5[62.371105]CRU:[62.371291]00000000:0000004b0000130180000000000001080000000700007f000000000000000000[62.372052]00000020:0000004b0000110180000000000001080000000700007f000000000000000000[62.372812]00000040:0000006b000013018000031f000001080000000700007f000000000000000000[62.373573]00000060:0000008b000016048000031f000001080000000700007f000000000000000000 ……

只需要修改 arch/arm64/configs/rockchip_linux_defconfig 文件,注释掉以下内容即可(此修改包含第二部分 USB 支持):

< CONFIG_PSI=y — >CONFIG_PSI=y98c98 < CONFIG_SCHED_RUNNING_AVG=y — >CONFIG_SCHED_RUNNING_AVG=y100c100 < CONFIG_SCHED_CORE_CTRL=y — >CONFIG_SCHED_CORE_CTRL=y139c139 < #CONFIG_SCHED_EAS=y — >CONFIG_SCHED_EAS=y4395c4395 < CONFIG_USB_ACM=y — >#CONFIG_USB_ACMisnotset4433c4433 < #CONFIG_USB_DWC3_HOST=y — >#CONFIG_USB_DWC3_HOSTisnotset4511c4511 < CONFIG_USB_SERIAL_QT2=y — >#CONFIG_USB_SERIAL_QT2isnotset 注释:红色内容为修改后的文件。解决上边崩溃问题只需要关闭 CONFIG_SCHED_EAS 一个配置即可。

①CONFIG_PSI PSI (Pressure Stall Information) 机制,其核心思想是:如果有进程因为等待某种资源而 stall 了,那说明这个时候资源成了一个限制条件(生产资料的短缺导致了生产力的损失),那就应该适当增加分配给这个进程的资源。 在部署业务时,如果过于保守地追求安全,那资源往往得不到充分的利用,造成浪费,在成本上丧失竞争力。 而如果对资源进行过饱和使用(比如内存的 overcommit),又可能导致运行过程中的波动(spike),影响延迟敏感型的任务,甚至最终不得不走向 OOM。

所谓人尽其才,物尽其用,Linux 中 PSI 的目标就是让硬件资源的效能最大化。

②CONFIG_SCHED_RUNNING_AVG

用于确定平均运行队列的调度程序接口。

③CONFIG_SCHED_CORE_CTRL

OpenHarmony CPU 轻量级隔离特性介绍。 基本概念 CPU 轻量级隔离特性提供了根据系统负载和用户配置来选择合适的 CPU 进行动态隔离的能力。 内核会将被隔离 CPU 上的任务和中断迁移到其他合适的 CPU 上执行,被隔离的 CPU 会进入 ilde 状态,以此来达到功耗优化的目标。同时提供用户的配置和查询接口来实现更好的系统调优。 配置指导 使能 CPU 轻量级隔离特性:打开相关配置项及依赖。启用 CPU 轻量级隔离,需要通过编译内核时打开相应的配置项及依赖,相关 CONFIG 如下。

④CONFIG_SCHED_EAS 能量感知调度(EAS)使调度程序能够预测其决策对 CPU 消耗的电量的影响。 EAS 依赖于 CPU的能量模型 (EM) 来为每个任务选择省电的 CPU,同时要求对执行任务的吞吐量的影响最小。 EAS 仅在异构 CPU 架构上(例如 Arm big.LITTLE)上运行,因为这是通过调度器节省电量的效果最大的地方。

多模子系统服务加载错误

错误日志 log:

[pid=1][Init][ERROR][init_signal_handler.c:42] Childprocessmultimodalinput(pid1351)exitwithsignal:11[pid=1][Init][INFO][init_signal_handler.c:51] SigHandler,SIGCHLDreceived,Service:multimodalinputpid:1351uid:6696status:11.[pid=1][Init][INFO][init_common_service.c:497] Reapservicemultimodalinput,pid1351.[pid=1][Init][ERROR][init_common_service.c:540] Servicename=multimodalinput,crash4times,nomorestart. 修改foundation/multimodalinput/input/service/window_manager/src/input_windows_manager.cpp文件 diff–gita/service/window_manager/src/input_windows_manager.cppb/service/window_manager/src/iindex1be96f7..6146c01100644 —a/service/window_manager/src/input_windows_manager.cpp +++b/service/window_manager/src/input_windows_manager.cpp@@-229,6+229,7@@ int32_tlogicX=mouseLocation.physicalX+displayInfo->x;int32_tlogicY=mouseLocation.physicalY+displayInfo->y;std::optionalwindowInfo; +CHKPV(lastPointerEvent_); if(lastPointerEvent_->GetPointerAction()==PointerEvent::POINTER_ACTION_MOVE&&lastPointerEvent_->GetPressedButtons().empty()){ windowInfo=GetWindowInfo(logicX,logicY);@@-396,6+397,7@@ { CALL_INFO_TRACE; std::optionalwindowInfo; +CHKPV(lastPointerEvent_); if(lastPointerEvent_->GetPointerAction()==PointerEvent::POINTER_ACTION_MOVE&&lastPointerEvent_->GetPressedButtons().empty()){ windowInfo=GetWindowInfo(lastLogicX_,lastLogicY_);

总结

经过以上修改之后,系统完全启动进入桌面之后,输入 power-shell setmode 602 命令,设置电源模式,防止系统重启,鼠标可正常工作。

审核编辑:汤梓红

猜你喜欢