编译WSL内核,用于操作usb读卡器

2023-12-04 23:36

本文主要是介绍编译WSL内核,用于操作usb读卡器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

wsl2默认不能操作usb读卡器,但是对于嵌入式linux开发来说,需要经常对tf卡进行操作,随时都会使用到usb读卡器的访问。下面讲述如何开启wsl2的usb读卡器的访问,主要涉及到以下2个步骤:

  • wsl2本质是一个虚拟机,无法直接访问宿主主机的USB设备。
  • wsl2的内核没有加入USB存储设备的驱动。

一、开启wsl2的usb识别

  • 1.1、windows安装 USBIPD-WIN 项目(官方指导教程)

    • ① 转到 usbipd-win 项目的最新发布页。

    • ② 选择 .msi 文件,点击后会进行下载。
      在这里插入图片描述

    • ③ 运行下载的 usbipd-win_x.msi 安装程序文件。

    下载完后点击安装就好,安装完后还会要求你重启电脑。

  • 1.2、wsl2下安装 USBIP 工具和硬件数据库

    sudo apt install linux-tools-generic hwdata
    sudo update-alternatives --install /usr/local/bin/usbip usbip /usr/lib/linux-tools/*-generic/usbip 20
    

    如果安装失败,先执行sudo apt update,再进行安装。

  • 1.3、attach usb设备到wsl2
    在attach USB 设备之前,请确保 WSL 命令行已打开。

    • ① 通过以管理员模式打开 PowerShell 并输入以下命令,列出所有连接到 Windows 的 USB 设备:
    usbipd wsl list
    

    如下:
    在这里插入图片描述

    • ② 选择要attach 到 WSL 的设备总线 ID,然后运行此命令:
    usbipd wsl attach --busid <busid>
    

    如下:
    在这里插入图片描述

    • ③ 打开 wsl2,使用以下命令列出附加的 USB 设备:
    lsusb
    

    如下:
    在这里插入图片描述

  • 1.4、从wsl2 detach usb设备
    在wsl2中完成设备使用后,可物理断开 USB 设备,或者在管理员模式下从 PowerShell 运行此命令:

    usbipd wsl detach --busid <busid>
    

此步执行完成后,虽然能识别到usb设备了,但是并没有创建块设备节点(/dev/sd*)。下面的操作就是用来解决这个问题。

二、开启wsl2的usb存储设备驱动

这部分需要重新编译wsl2的内核,开启内核的usb存储设备驱动,编译后进行内核替换。

  • 2.1、首先到wsl2的内核仓库中获取一份内核源码:

    git clone https://github.com/microsoft/WSL2-Linux-Kernel.git
    

    或直接下载zip文件,比较快:
    在这里插入图片描述

  • 2.2、解压源码:

    unzip WSL2-Linux-Kernel-linux-msft-wsl-5.15.y.zipcd WSL2-Linux-Kernel-linux-msft-wsl-5.15.y
    
  • 2.3、使用以下命令来配置内核配置:

    make menuconfig KCONFIG_CONFIG=Microsoft/config-wsl
    
  • 2.4、进入 Device Drivers -> USB support -> Support for Host-side USB ,选中 USB Mass Storage support( * 号是直接编译进内核,M 是编译为内核模块,内核模块需要手动加载),把下面弹出来的一堆驱动都选上,保存完之后就可以退出了。
    在这里插入图片描述

  • 2.5、执行以下命令开始编译内核:

    make -j$(nproc) bzImage KCONFIG_CONFIG=Microsoft/config-wsl
    

    编译完成的内核是bzImage文件,和我们编译时指定的名称一致,文件在arch/x86/boot/文件夹下。

  • 2.6、把编译好的内核复制出来,放在 Windows 的用户目录(默认是 C:\Users\{username})下创建一个名为 .wslconfig 的文件,内容根据 微软官方文档 来:

    [wsl2]
    kernel=path\\to\\kernel
    

    以下是我的配置:
    在这里插入图片描述

  • 2.7、检查新内核是否生效
    重启wsl2,使用以下命令来查看内核版本号:

    uname -a
    

    对比下显示的日期是否和编译日期一样。

三、wsl2访问usb读卡器

  • 3.1、usbipd-win的使用,方法也是参考的微软官方文档。
    管理员方式打开powershell:
    # 将usb从windows接入到wsl,此时windows端会断开
    usbipd wsl list
    usbipd wsl attach --busid <busid>
    
  • 3.2、wsl2访问usb
    # 查看usb接入情况
    lsusb
    # 查看内核日志
    dmesg# 查看对于的块设备节点
    ls /dev/sd*
    
  • 3.3、使用完成之后,断开usb
    # 此命令执行完成后,usb将从wsl断开,windows端会接入
    usbipd wsl detach --busid <busid>
    

这篇关于编译WSL内核,用于操作usb读卡器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/455312

相关文章

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用Python的requests库来发送HTTP请求的操作指南

《使用Python的requests库来发送HTTP请求的操作指南》使用Python的requests库发送HTTP请求是非常简单和直观的,requests库提供了丰富的API,可以发送各种类型的HT... 目录前言1. 安装 requests 库2. 发送 GET 请求3. 发送 POST 请求4. 发送

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

MySQL 临时表与复制表操作全流程案例

《MySQL临时表与复制表操作全流程案例》本文介绍MySQL临时表与复制表的区别与使用,涵盖生命周期、存储机制、操作限制、创建方法及常见问题,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随小... 目录一、mysql 临时表(一)核心特性拓展(二)操作全流程案例1. 复杂查询中的临时表应用2. 临时

MySQL 数据库表与查询操作实战案例

《MySQL数据库表与查询操作实战案例》本文将通过实际案例,详细介绍MySQL中数据库表的设计、数据插入以及常用的查询操作,帮助初学者快速上手,感兴趣的朋友跟随小编一起看看吧... 目录mysql 数据库表操作与查询实战案例项目一:产品相关数据库设计与创建一、数据库及表结构设计二、数据库与表的创建项目二:员