- 博客(1174)
- 资源 (77)
- 收藏
- 关注
原创 C语言 BMP图片的旋转与缩放
printf("位图实际数据大小:%d_%d(kb)\n", srcBmpInfoHeader->biSizeImage, srcBmpInfoHeader->biSizeImage / 1024);printf("文件大小:%d_%d(kb)\n", srcBmpFileHeader->bfSize, srcBmpFileHeader->bfSize / 1024);//写入位图实际数据。printf("位图实际使用的颜色数:%d\n", srcBmpInfoHeader->biClrUsed);
2024-03-04 16:35:12 1725
原创 图像传感器与信号处理——SFR算法/ISO 12233解读
(2)文中提到,相机拍摄的Test Chart可能并不是占据整张像,因此获得的结果也需要按照Test Chart的大小比例进行放缩,例如,图像中的Test Chart只占据整张图像的1/2,按照Test Chart获得的结果是2000LW/PH,那么相机的实际分辨率是4000LW/P。以我的理解,ISO 12233这篇文章主要是规定了摄像头分辨率的测量标准,一共有三种方法:基于视觉的分辨率测量方法,基于边界的SFR算法以及基于正弦波的SFR算法。
2024-03-04 16:32:15 2350 2
原创 最小二乘法C语言的实现
printf ("\n请输入您要处理的数据的组数(提示:程序定义一对x,y值为一组数据):");printf ("请输入第%d个x的值x%d=",i+1,i+1);printf ("\n请输入你要修改的第%d个x的值x%d=",z,z);printf ("\n请输入第%d个x的值x%d=",i+1,i+1);printf ("\n请输入你要修改的对应的y的值:y%d=",z);printf (" 输入对应的y的值:y%d=",i+1);printf ("\n请输入对应的y的值:y%d=",i+1);
2024-03-04 16:30:41 843
原创 OpenCV | 直线拟合fitline函数(Python)
之前做直线拟合时,自己写了一个利用最小二乘做直线拟合的程序,但是由于直线检测的误差比较大,拟合的效果并不好。个人不知道是什么原因,因此想尝试更改一下直线拟合的算法,后来找到了OpenCV中的fitline函数,也是一个距离最小化函数,它完全包含了最小二乘法。output : 对于二维直线,输出output为4维,前两维代表拟合出的直线的方向,后两位代表直线上的一点。注意,这里是N条直线的直线拟合,拟合思路为提取N条直线的坐标点,然后进行点的直线拟合。这里,data_line1 表示直线检测出的直线的数据。
2024-03-04 16:29:25 1848
原创 用Visual Studio 2015成功编译、发布UMDF驱动到目标机!!
D,上面点击“下一步”按钮后,就进入了主机和目标机建立通讯的过程,这个过程需要一些时间,要耐心等待完成,不要进行其它操作,期间目标机会进行多次重启操作,都是自动完成,我们不要进行任何人为干预!B,点击VS2015的菜单“生成”->“部署 UMDF 2 Driver1”,注意,这里面的“UMDF 2 Driver1”是我当前建立的工程名称,如果你的工程名称和我的不一样,那么只是后面的工程名称不同而已,也是选择这个菜单项!C,对这个驱动进行编译,如果一切顺利,那么从输出窗口,我们应该能看到编译成功的信息!
2024-02-27 10:27:46 947
原创 测试模式
bcdedit.exe /set nointegritychecks onbcdedit.exe /set nointegritychecks offbcdedit /set testsigning onbcdedit /set testsigning off
2024-02-23 11:44:10 61
原创 像素格式转换
使用ffmpeg的swscale_scale函数可以实现像素格式转换,具体代码如下:#include <libavcodec/avcodec.h>#include <libswscale/swscale.h>int main(){ // 初始化转换器 struct SwsContext *sws_ctx = sws_getContext(width, height, AV_PIX_FMT_YUYV422, width, height, AV_PIX
2024-01-08 08:43:28 855
原创 CH340串口驱动(包含各系统平台)
说明:CH340/CH341 USB转串口WINDOWS驱动程序,支持32/64位Windows 11/10/8.1/8/7/VISTA/XP,SERVER 2022/2019/2016/2012/2008/2003,2000/ME/98,通过微软数字签名认证,支持USB转UART/3线和9线SERIAL串口等,用于随产品发行到最终用户。CH340/CH341/CH342/CH343/CH344/CH347/CH9101/CH9102/CH9103/CH9143 MAC驱动链接。
2023-11-30 10:25:31 3402
原创 PCIe 配置空间:Command 寄存器
该位为 0 时,Root Port 或者 Switch 的 Downsteam 端口收到 Memory 请求和 I/O 请求后,应该按照 Unsupported Requests(UR)处理。除了 Memory 读写请求和 I/O 读写请求,其他类型的请求不受该位控制。除了 Memory 读写请求和 I/O 读写请求,其他类型的请求不受该位控制。该位为 0 时,不允许设备发出 Memory 读写请求、I/O 读写请求。该位为 1 时,允许设备发出 Memory 读写请求、I/O 读写请求。
2023-09-05 09:03:53 781
原创 C语言socket传输文件
可以传输大型文件,其基本思想为把文件名字读出来放到filename数组中,然后copy到buffer中,接着将独到的文件内容接在buffer数组中文件名称后面。然后循环读取,以后每次将独到的数据放入buffer传输。TCP服务端和TCP客户端编程,完成文件传输(客户端输入文件名,服务端接收文件数据并保存至服务端本地)此文件是在Linux系统运行的,Windows中不包含socket等头文件。关于头文件可以参考socket编程中用到的头文件。关于用到的函数可以通过查询C 语言教程。下面是客户端端的代码。
2023-06-29 17:09:55 680
原创 Ubuntu 18.04安装 RT-PREEMPT 实时内核及补丁【过程记录】
Ubuntu 18.04安装 RT-PREEMPT 实时内核及补丁【过程记录】1、查看当前内核版本2、下载内核和补丁3、配置内核4、编译内核5、安装 deb 包6、reboot 并验证7、参考8、给实时内核安装 nvidia 显卡驱动8.1 进入之前的非实时内核系统中查看nvidia 驱动版本号8.2 卸载 nvidia 驱动(非实时内核中)8.3 查看适配的 nvidia 版本(非实时内核中)8.4 安装推荐版本的 nvidia 驱动(非实时内核中)
2023-05-19 10:13:14 1020
原创 【UEFI实战】EFI System Table中的输入输出
gEfiSimpleTextOutProtocolGuid的安装对应到不同的情况,比如对于串口就需要有gEfiSerialIoProtocolGuid,对于显示器就需要依赖于gEfiUgaDrawProtocolGuid或者gEfiGraphicsOutputProtocolGuid等与图形输出有关的protocols。这里有一个循环,可以起到多个位置打印的效果,而ConSplitterTextOutAddDevice()可以增加输出位置。DEBUG,它一般通过串口输出,这个是调试的时候最常用的;
2023-05-09 11:32:40 867
原创 【UEFI实战】Linux下如何解析ACPI表
上述的iasl工具获取ACPI表需要从特定目录去拿,比较复杂,这里还可以用一个简单的工具acpidump来获取。iasl是一个编译和解析ACPI的工具,在编译UEFI的时候也是必不可少的。之后就可以通过iasl命令来解析ACPI文件了。本文介绍如何在Linux下查看ACPI表示。以上就是对APCI表在Linux下解析的一些说明。所以需要借助额外的工具来查看。
2023-05-09 11:32:36 1345
原创 【UEFI基础】ACPI基础
为了让OSPM能够控制计算机上的设备的资源和热插拔,ACPI提供了一种描述这些设备的信息和控制方式的结构,称为ACPI Definition Blocks,它们按照一种层级结构组织,这种组织方式成为ACPI Namespace。因为OS控制了设备和CPU的电源和性能,所以也需要通过ACPI来管理温度,ACPI中可以方便的定义温度区域,温度指示器和冷却温度区域的方法。ACPI表描述了计算机包含的设备以及它们的电源状态(D状态,D0表示正常状态,数字越大性能和耗能越小),使设备进入不同电源状态的控制方式。
2023-05-09 11:31:22 2128
原创 UEFI开发探索13 – 访问PCI/PCI-E设备1
从实践中知道,PCI I/O Protocol可以访问改在在主板上的所有PCI设备,而PCI Root Bridge I/O Protocol不能访问PCI to PCI桥设备。UEFI Spec中有两个protocol可以访问PCI设备,PCI Root Bridge I/O Protocol和PCI I/O Protocol。配置空间包括一系列的PCI配置寄存器,其实现位置可以在PCI配置空间中,或者IO空间,也可以直接在申请的memory空间中实现。代码中以此函数,获取所有能找到的PCI设备。
2023-04-23 15:48:14 722
原创 Uefi编程 检查Pcie设备是否支持ASPM功能
WritePci.c (待完善,需要保持其他寄存器值不变)对pci设备某个寄存器实现写功能。WritePci.inf文件。Aspm.inf文件。
2023-04-23 12:39:03 770 1
原创 如何在飞腾平台上安装Ubuntu操作系统
注意: 若主板上配置的是NVME硬盘,在进行内核配置时,需要将内核的NEME驱动勾选上,否则移植内核时,无法找到文件系统,进不去操作系统。可以通过rufus软件将镜像做到U盘中,本次使用版本为Rufus 3.9.124 ,其他版本也可以。不要下载live版本的,没有准备网络环境,是一个头疼的事情,笔者暂时没有实现网络安装。将U盘接到主板usb口上,接上串口,显示器,,必需串口有打印才可以安装。可以通过dd命令,将iso安装到U盘。安装的是最小系统,缺少很多命令,需要联网更新,或则更换飞腾专用内核。
2023-04-23 09:24:22 1411
原创 读取飞腾套片X100内部温度和chipID
上面返回共16字节有效数值0x4b 0x50 0x41 0x30 0x34 0x39 0x30 0x31 0x33 0x32 0x31 0x39 0x30 0x30 0x30 0x30,转换成ASCII字符串,即“KPA0490132190000”。sudo i2ctransfer -f -y 1 w10@0x18 0x00 0x70 0x02 0x10 0x28 0x00 0x00 0x00 0x01 0x01 //低32bit。//读取chipID 高32-bit。//读取chipID。
2023-04-23 09:21:14 933
原创 coreboot & seabios
seabios现在是很多虚拟机的默认启动bios,这跟它的短小精干有很大关系,也跟它提供比较完备的legacy支持有关。按照以下步骤把seabios制作成coreboot的payload,最新的代码是seabios v1.7.3.1建议先试用seabios v1.7.2,因为下面提供的参考.config文件基于seabios v1.7.2。如果运行该命令时报错,一般可安装所需的library解决。
2023-04-17 09:59:51 998
原创 在Ubuntu18.04或者20.04下搭建edk2运行环境
4.安装OpenSSL* Crypto 库:https://github.com/openssl/openssl/archive/OpenSSL_1_1_0g.zip,下载解压至目录UDK2018\CryptoPkg\Library\OpensslLib,并命名为openssl。1.下载edk2源码https://github.com/tianocore/edk2/releases/tag/vUDK2018。也可下载最新版edk2。(最好下载Linux下的.tar.gz类型的源码文件。
2023-04-15 11:46:53 503
原创 Ubuntu16.04 python2.7升级python3.5
安装完成之后,你在终端中输入python,输出的信息里面会提示是2.7版本的,也就是说默认打开的并不是刚才安装好的3.5,所以还需要我们重新修改一下链接。正常情况下,你安装好ubuntu16.04版本之后,系统会自带 python2.7版本,如果需要下载新版本的python3.5,就需要进行更新。输入你的密码后会下载,刚才下载的Python程序被安装在usr/localb/python3.5 中。2.指定默认打开的是python3.5版本(你新安装的python版本)。至此,python版本更新已经完成。
2023-04-15 11:43:25 763 1
原创 Ubuntu 18.04系统中可用并行算法库的GCC-9安装
使用C++17需要gcc为7.0以上版本即可,但要使用C++ 17 STL并行算法库,必须是9.1以上版本。Ubuntu 16.04系统中使用GCC 9.1及Intel TBB库运行C++17 STL并行算法库。如果输入选项2,则会将系统默认调用的gcc版本定为9。我需要使用并行库,但gcc为7.5版本,故有此文。可以看到我这里是gcc7.5。如果还想装其他版本可参考链接。接下来TBB的安装请参考。
2023-04-15 11:40:31 951
原创 UEFI Device Path (1): 重新认识Device Path
每个variable的内容都包含1个Device Path,这个Device Path表示每次开机默认使用的用于该种用途(ConIn,ConOut, ErrOut)的Console Device,UEFI应用可以通过这个Device Path来确定对应的Console Device。Messaging Device Path IDE设备,USB设备,SATA设备,SAS设备,SCSI设备,UART设备,Vendor自定义对象,MAC地址,IPv4/IPv6地址,其他新兴设备。
2023-04-06 08:21:54 1060
原创 UEFI BootOption Variable存储字节流
可以看到Boot0000,Attribute 0x108, 是unactive的,FilePathSize 0x2c,描述就是,**** Setupo Utility。可以知道Attribute占4个字节,路径长度FilePathSize 2个字节。然后是设备描述,是Unicode字串串,以0x0,0x0结尾,然后跟着的就是FilePath.图中的Boot0000就是存储启动项Boot0000的属性变量名称,启动路径的数据。这个是BootOption结构体,但是实际上的存储并不是按照这个格式存储的。
2023-04-03 21:23:29 562 1
原创 Ipmi 之Boot Option
找到之后判断一下如果这个BootType和之前的不一样,那就调用通知的函数,也就是给bmc发送命令的函数IpmiSetBootFlags,如果发送成功,更新一下对应的variable。在bios启动过程中,到Bds阶段,会遍历所有的BootOption,并创建BootOrder variable,然后会根据BootOrder中的顺序,来获取第一启动项,并通过variable Boot000#(# 代码启动顺序的id,数值0-N),下面详细的看一下遍历系统启动项,已经注册Boot000#的过程。
2023-04-03 21:17:37 2547 2
原创 UEFI下BootOption
如果BootOption不是这种NVME,比方说,你想要设置一个硬盘里面的/test/test.efi作为一个启动项,你可以使用PciRoot(0x0)/Pci(0xF,0x0)/Pci(0x0,0x0)/NVMe(0x1,3E-12-30-80-44-A7-79-64)/HD(6,GPT,C75CD876-DC80-4DF8-B6A4-7B2111703BA6,0x16E7B000,0x3C78000)/\test\test.efi。其中OptionNumber就是0,1,2,3,4,5依次递增。
2023-04-03 21:10:34 1669 1
原创 【UEFI基础】OVMF设置默认启动项为UEFI Shell
当然如果需要设置其他的启动项为默认项,只需要修改BootOptionPriority 中 StrCmp (BootOption->Description, L"EFI Internal Shell")为 StrCmp (BootOption->Description, L"XXXX")。之前由于NT32编译的虚拟环境一直卡在中途,无法进入Shell,一直使用的是OVMF. OVMF确实挺好用的,只是进入shell环境时网络启动一直优先,太费时间了,正好看到CSDN里面的博主有改了这块。
2023-04-03 11:55:49 451
原创 BIOS PEI Phase涉及模块函数一览
硬件相关初始化动作,大部分都是在Pei Phase、Dxe 前期Non EFI Driver Model的Driver, 初始化Processor、Chipset或Platform,当然有些也通过Oprom 或file in an EFI System Partition来进行初始化。主要功能是加载并连接驱动程序,管理并启动引导项。在引导操作系统之前会初始化设备(USB键盘鼠标,VGA设备等),然后通过Variable功能来控制启动顺序,根据启动策略加载对应的引导项,启动操作系统或应用程序。
2023-04-03 08:16:30 500 1
原创 BIOS的BDS阶段解析
硬件相关初始化动作,大部分都是在Pei Phase、Dxe 前期Non EFI Driver Model的Driver, 初始化Processor、Chipset或Platform,当然有些也通过Oprom 或file in an EFI System Partition来进行初始化。主要功能是加载并连接驱动程序,管理并启动引导项。在引导操作系统之前会初始化设备(USB键盘鼠标,VGA设备等),然后通过Variable功能来控制启动顺序,根据启动策略加载对应的引导项,启动操作系统或应用程序。
2023-04-03 08:16:19 922
原创 PEI阶段扩展——pei和dxe之间通过hob传递参数
传入的参数第一个为Hob的GUID,所有的UEFI元素都有自己的GUID,传入得到的返回结果就是HOBlist ,通过的是configration table去抓的(属于systemtable的成员),每个DXE Driver的entrypoint都有两个参数imaginehandle 和systemtable,故而可以通过systemtable可以访问整个系统的资源。在PEI和DXE之间通过HOB 传递参数。这里的既定顺序即Dependency顺序,就是inf文件里面的depx,只有满足条件才会执行。
2023-04-03 08:14:35 805
原创 UEFI启动过程与协议加载顺序
HOB在PEI到DXE传送信息的过程遵循one Producer to one Consumer的模式,即在PEI阶段,一个PEIM创建一个HOB,在DXE阶段,一个DXE Driver使用那个HOB并且把HOB相关的信息传送给其他的需要这些信息的DXE组件。其中一个队列存放当前已经满足依赖项,可以加载的驱动的指针,另一个则存放当前已经找到但还未满足加载条件的所有驱动的指针,调度器每循环一次都会完成第一个队列中一个驱动的加载,同时将第二个队列中的项目检查一遍,若已满足依赖项则移到第一个队列中。
2023-04-01 07:54:04 1284 1
原创 UEFI 基础教程 (十四) - 设置默认启动项为UEFI Shell
设置Shell为默认启动项后,BIOS启动会优先加载Shell(对于OVMD而言就不用等待前面的PXE、QEMU USB加载了, 可以节省时间)。当然如果需要设置其他的启动项为默认项,只需要修改BootOptionPriority 中 StrCmp (BootOption->Description, L"EFI Internal Shell")为 StrCmp (BootOption->Description, L"XXXX")。二、 编译生成EFI文件 & 运行。
2023-03-31 10:37:23 1578 1
原创 UEFI 基础教程 (三) - 运行第一个PEI Driver
一、 编写源代码编写C:\edkii\OvmfPkg\MyHelloWorldPEIMDriver\MyHelloWorldPEIMDriver.cEFI_STATUSEFIAPI编写C:\edkii\OvmfPkg\MyHelloWorldPEIMDriver\MyHelloWorldPEIMDriver.inf[Defines][Sources][Packages]BaseLibDebugLib。
2023-03-31 10:09:05 551 2
原创 SeaBIOS实现简单分析
当段寄存器被重新赋值的时候,就根据段选择子,从存储器中读取GDT中的项,然后将段基址以及其他的段描述符信息存储在这个段寄存器对应的段描述符高速缓冲寄存器中。笔者猜测这一一点的实现方式是通过段描述符高速缓冲寄存器实现的(实模式下也是通过查询这个寄存器来获得段基址的),开机的时候代码段的对应基址项被设置成0xFFFF0000。从代码的Read sector部分可以看出,boot_disk将读取使用bootdrv指定的磁盘驱动器上,0磁头,0柱面,1扇区为起始位置,扇区数为1(512字节)的一段数据。
2023-03-29 09:26:56 733 1
转载 【UEFI实战】HII之vfr文件
https://blog.csdn.net/jiangwei0512/article/details/122824342
2023-03-23 21:18:30 360
e1000e-3.8.4.tar.gz
2020-08-17
win7 vs2012+wdk8.0 pci驱动源码 Solution.zip
2019-05-27
后台服务监控应用
2019-03-14
删除vs垃圾
2019-01-05
基于HI3531d的udp命令控制basler pylon gige工业相机程序
2018-12-05
基于hi3531、3531d的yuv压缩h264
2018-11-22
基于hi3531的live555例子(发送h264)
2018-11-20
hi3531\3531a\3531d\3536\3536d\3559\3559a\3519SDK
2018-11-16
基于basler工业相机的H264压缩
2018-10-29
dm642_PCI_INTA
2017-09-13
REALTEK刷机方法
2016-12-20
STC的CDB文件
2016-12-01
uefi的protocol例子
2023-03-18
Windows Embedded Standard 7 快速入门指南1234.pdf
2021-02-26
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人