SAE J1699-1-2021 是一份关于道路车辆OBD-II(On-Board Diagnostics II)验证测试程序的标准文档,由SAE(美国汽车工程师学会)发布,旨在推动汽车技术与工程科学的发展。
这个标准是自愿采用的,其适用性和对于任何特定用途的适合性,包括可能由此引发的专利侵权问题,均由使用者自行负责。


OBD-II系统是汽车诊断的一种标准,它允许技术人员通过车辆的数据端口访问和分析车辆的故障信息。
SAE J1699-1标准详细规定了如何验证这些系统是否符合规定的性能和兼容性要求。
这份2021年的更新版本是对2006年版的J1699-1标准的修订或确认,确保与当前汽车技术保持同步。


J1699-1标准的稳定化(Stabilized)状态意味着其中涵盖的技术、产品或过程已经成熟,不太可能在可预见的未来发生重大变化。
这意味着尽管这个标准被认定为稳定,但用户仍然需要定期检查参考信息,以确保技术要求的持续适用性,因为可能存在更新的技术。


此标准包含了OBD-II系统的测试步骤和程序,旨在确保车辆制造商生产的OBD-II接口能够准确、一致地报告和处理车辆的诊断信息。
这些测试可能包括但不限于通信协议一致性、故障代码设置的正确性、故障指示灯的触发条件以及数据流的准确传输。


该标准还涉及到SAE J1850,这是一个早期的通信协议,用于OBD-II系统中,用于在车辆的ECU(电子控制单元)和诊断工具之间交换信息。
J1699-1标准可能会扩展到其他通信协议,以适应现代车辆中更复杂的网络架构和更高的数据传输需求。


SAE J1699-1-2021的实施可以帮助确保车辆的排放控制系统的有效性,因为它要求OBD-II系统能够检测和报告任何可能导致排放超过法定限值的故障。
这有助于维护环境法规的执行,并促进汽车行业的技术进步和创新。


要获取这份标准的完整内容,可以联系SAE International,通过电话、传真或电子邮件下单,或者访问其官方网站进行在线购买。
同时,SAE也鼓励用户提供书面评论和建议,以帮助持续改进这些标准。
2025/5/21 22:54:09
1
PytorchimplementationofCRAFTtextdetector
2025/5/21 9:05:13 858KB Python开发-机器学习
1
【DM365_NAND启动模式解析】DM365是一款由TexasInstruments(TI)生产的数字媒体处理器,常用于视频处理和嵌入式系统。
在DM365中,NAND闪存是一种常见的非易失性存储器,用于存储固件和操作系统。
NAND启动模式是指DM365在上电或复位后从NAND闪存中加载启动代码的过程。
此过程涉及一系列复杂的步骤,确保系统能够正确地从NAND中读取和执行固件。
**NAND启动流程**1.**初始化**:系统首先初始化RAM1的高2KB栈空间(0x7800-0x7fff),避免覆盖用于存储UBL块号的最后32个字节(0x7ffc-0x8000)。
2.**禁止中断**:所有中断(IRQ和FIQ)被禁用,以确保启动过程不被打断。
3.**设置DEEPSLEEPZ/GIO0**:这个外部引脚在NAND启动时必须处于高电平。
4.**读取NANDID**:读取NAND闪存的设备ID,获取设备特性,如页面大小、块大小等。
5.**初始化NAND区域**:根据NAND的参数设置控制器和寄存器。
6.**搜索UBL描述符**:RBL(ROMBootloader)在block1的page0开始搜索UBL(UserBootLoader)的描述符。
如果未找到正确的UBL,会依次检查接下来的24个块,以防遇到坏块。
7.**处理UBL描述符**:UBL描述符包含入口点地址、占用的NAND页数、起始块和起始页等信息,用于指导UBL的加载和执行。
8.**ECC错误检测和校正**:开启硬件ECC(ErrorCorrectionCode)检测,复制UBL到IRAM(InternalRAM)。
如果检测到4位ECC错误,通过ECC算法进行纠正。
如果多次失败,RBL会尝试下一个块,直到找到有效的UBL描述符,或者在搜索完24个块后转而从SD卡启动。
9.**启动UBL**:在UBL的入口点执行代码,将控制权交给UBL。
10.**安全启动模式**:根据配置,启动模式可能包括PLL旁通模式,不使用快速EMIF、DMA或I-Cache。
在其他模式下,这些功能可以被启用以提高性能。
**NANDUBLdescriptor格式**UBL描述符是一个包含关键信息的数据结构,用于指示如何加载和执行UBL。
它可能包含如下字段:-入口点地址:UBL执行的起点。
-UBL占用的NAND页数:指示UBL的大小,必须是连续的页。
-UBL的起始块和起始页:定义UBL在NAND中的位置。
-MAGICIDs:特定的标识符,用于识别不同的启动模式。
**NAND启动详细流程**1.初始化栈空间、禁止中断、设置DEEPSLEEPZ/GIO0。
2.读取NAND设备ID,初始化NAND控制器。
3.搜索UBL描述符,最多遍历24个块。
4.复制并校验UBL到IRAM,根据UBL描述符配置启动选项。
5.转交控制权给UBL执行。
NAND启动流程图和具体的ARMNANDROMBootloader实例进一步详细说明了这个过程。
此外,支持的NAND设备ID列表确保了对多种NAND闪存设备的兼容性。
DM365的NAND启动模式解析涉及了设备识别、错误检测、固件加载和执行等多个环节,确保了系统的稳定和可靠启动。
理解这一过程对于开发和调试基于DM365的嵌入式系统至关重要。
2025/5/20 16:04:21 249KB DM365
1
###TIDM36x系列DSPNANDFlash启动过程详解####一、NANDFlash启动原理#####1.1DM365支持的NAND启动特性TI的TMS320DM365(以下简称DM365)多媒体处理芯片支持多种启动方式,包括NANDFlash启动。
在NANDFlash启动过程中,DM365具有一系列独特的启动特性:1.**不支持一次性全部固件下载启动**:DM365不支持一次性将所有固件数据从NANDFlash读入内存并启动,而是采用分阶段的方式。
首先从NANDFlash读取第二级启动代码(UserBootLoader,UBL)至ARM内存(ARMInternalMemory,AIM),然后执行UBL。
2.**支持最大4KB页大小的NAND**:支持的NANDFlash页大小可达4KB,这对于大多数常见的NANDFlash设备来说是足够的。
3.**支持特殊数字标志的错误检测**:在加载UBL时会进行错误检测,尝试最多24次在不同的block中寻找特殊数字标志,以确保数据的正确性。
4.**支持30KB大小的UBL**:DM365有32KB的内存用于存放启动代码,其中2KB用于RBL(ROMBootLoader)的堆栈,剩余的空间可用来存储UBL。
5.**用户可选的DMA与I-cache支持**:用户可以根据需要在RBL执行期间启用或禁用DMA和I-cache等功能。
6.**支持4位硬件ECC**:支持每512字节需要ECC位数小于或等于4位的NANDFlash,这有助于提高数据的可靠性。
7.**支持特定的NANDFlash类型**:支持那些需要片选信号在Tr读时间保持低电平的NANDFlash。
#####1.2NANDFlash启动流程NANDFlash启动流程是指从芯片上电到Linux操作系统启动的整个过程,主要包括以下几个步骤:1.**ROMBootLoader(RBL)阶段**:当DM365芯片上电或复位时,会根据BTSEL引脚的状态确定启动方式。
如果是NAND启动,则从ROM中的RBL开始执行。
RBL会初始化必要的硬件资源,如设置堆栈,关闭中断,并读取NANDFlash的ID信息以进行适当的配置。
2.**UserBootLoader(UBL)阶段**:RBL从NANDFlash读取UBL并将其复制到AIM中运行。
UBL负责进一步初始化硬件资源,如DDR内存,并为下一阶段准备环境。
3.**U-Boot阶段**:UBL从NANDFlash读取U-Boot并将其复制到DDR内存中运行。
U-Boot是完整的启动加载程序,它负责最终从NANDFlash读取Linux内核并将其复制到DDR内存中。
4.**Linux内核启动阶段**:U-Boot启动Linux内核,内核加载并运行,此时系统完成启动。
####二、NANDFlash启动的软件配合实现#####2.1UBL描述符的实现UBL描述符是UBL读取和执行的起点。
在NANDFlash中,UBL描述符通常位于特定的位置,包含UBL的起始地址和长度等信息。
RBL通过读取这些描述符来确定UBL的具体位置并加载到AIM中。
#####2.2U-Boot启动实现U-Boot是一种开源的启动加载程序,负责从NANDFlash读取Linux内核并将其加载到内存中。
U-Boot的实现依赖于UBL提供的环境,例如已经初始化的DDR内存。
#####2.3U-Boot更新UBL和U-Boot的原理U-Boot可以被用来更新UBL和自身的代码。
这一过程通常涉及到从NANDFlash读取新的代码版本,验证其完整性,并将其替换现有的UBL或U-Boot代码。
#####2.4NANDFlash没有坏块的情况在理想情况下,即NANDFlash没有坏块的情况下,启动流程会非常顺利。
RBL能够成功地从NANDFlash读取UBL,UBL也能正确地读取U-Boot,进而完成Linux内核的加载。
####三、结束语DM365的NANDFlash启动过程是一个复杂的多阶段过程,涉及ROMBootLoader(RBL)、UserBootLoader(UBL)和U-Boot等多个组件之间的协调工作。
通过对这些组件的理解和优化,可以有效地提高启动速度和系统的稳定性。
希望本文能帮助读者更好地理解DM365的NANDFlash启动过程及其背后的技术细节。
2025/5/20 15:59:25 439KB DSP NANDflash 启动过程分析
1
###合众达dm365开发板linux下环境构建####一、概述《合众达dm365开发板linux下环境构建》主要介绍了SEED-DVS365开发软件用户指南的核心内容,这是一份针对SEED-DVS365平台的软件测试包、开发工具链及开发环境的详细指南。
本篇将从以下几个方面展开讨论:软件测试包的内容、CCS_V3.3测试平台的构建方法、硬件测试流程、Linux服务器下的开发套件安装配置与使用方法、系统启动方式的配置等。
####二、SEED-DVS365开发软件用户指南#####2.1文档目的该文档旨在为用户提供一个全面的指导手册,帮助用户了解如何构建基于SEED-DVS365平台的开发环境,并利用所提供的软件开发工具包进行高效开发。
#####2.2软件测试包内容软件测试包包括但不限于以下内容:-**测试程序**:用于验证开发板基本功能的测试代码。
-**驱动程序**:支持各种外设和硬件功能的驱动程序。
-**示例代码**:提供多种应用场景的示例代码,帮助开发者快速上手。
-**文档资料**:详细的操作指南和技术文档,确保开发者能够顺利进行项目开发。
#####2.3CCS_V3.3测试平台构建CCS(CodeComposerStudio)是一款集成开发环境(IDE),特别适用于TI系列处理器的开发。
构建CCS_V3.3测试平台主要包括以下步骤:-**安装CCS_V3.3**:按照官方指导手册完成IDE的安装。
-**配置硬件连接**:设置开发板与PC之间的通信接口。
-**创建工程**:在CCS中新建项目并配置必要的参数。
-**编译与调试**:编译工程并通过串口或JTAG接口下载至开发板进行调试。
#####2.4硬件测试流程硬件测试流程通常涉及以下步骤:-**物理检查**:确认硬件组件完整无损。
-**电源检测**:测试电源供应是否稳定可靠。
-**接口测试**:验证各种I/O接口的功能性。
-**系统启动**:确保开发板能够正确启动并进入预设状态。
-**功能验证**:通过测试程序对各项功能进行逐一验证。
#####2.5Linux服务器下的开发套件安装配置为了在Linux环境下进行开发,需要安装一系列的开发工具,具体步骤如下:-**安装必备工具**:如GCC编译器、Make工具等。
-**配置交叉编译环境**:设置目标平台的编译工具链。
-**安装调试工具**:如GDB调试器。
-**配置网络连接**:确保开发板与服务器之间能够进行数据传输。
#####2.6启动方式配置启动方式的配置对于系统启动过程至关重要,常见的启动方式包括:-**U-Boot启动**:通过U-Boot引导加载程序加载内核镜像。
-**SD卡启动**:从SD卡加载内核镜像和根文件系统。
-**网络启动**:通过网络下载内核镜像和根文件系统。
-**NANDFlash启动**:直接从NANDFlash加载内核镜像。
####三、维护和升级北京合众达电子技术有限责任公司提供了为期一年的免费软件维护和升级服务,确保用户能够在服务期内获得稳定的软件支持。
此外,还提供了一些重要的警告信息和注意事项,以避免不必要的损失。
####四、参考文献文档还提供了多个参考文献链接,其中包括了TMS320DM365CPU架构及其外设资源的详细介绍、TMS320DM36x系统的ARM子系统、视频处理前后端模块、DDR2存储器控制器、异步外部存储器接口、增强型DMA控制器和EMAC模块等多个方面的技术文档。
这些文档对于深入了解SEED-DVS365开发板的功能和特性具有重要意义。
####五、总结《合众达dm365开发板linux下环境构建》不仅为开发者提供了详尽的开发指导,还涵盖了软件测试包、开发工具链、硬件测试流程等多个方面,有助于用户高效地进行嵌入式系统的开发。
通过遵循本指南中的指导,开发者可以更好地利用SEED-DVS365开发板的强大功能,实现自己的项目目标。
2025/5/20 13:22:51 587KB
1
【DM365启动机制与Boot】深入解析

DM365是一款由德州仪器(TI)推出的DaVinci系列数字媒体处理器,广泛应用于多媒体设备、视频处理和图像处理等领域。
其启动过程涉及到复杂的硬件初始化和软件加载流程,理解这一过程对于开发和调试基于DM365的系统至关重要。


DM36X的启动机制遵循一个标准的流程,当系统加电或复位后,CPU会从预先设定的地址读取第一条指令。
DM36X提供了多种启动方式,主要分为两种:通过外部存储器接口AEMIF(NOR Flash/OneNand)引导启动和通过ARM内部ROM(AIROM)引导启动。
启动模式的选择由BTSEL[2:0]引脚的状态决定。


例如,当BTSEL[2:0]设置为001时,系统将从AEMIF执行引导启动代码,即从外部的OneNand或Nor Flash启动。
而AIROM则支持多种启动模式,包括BTSEL[2:0]=000的NAND Boot,BTSEL[2:0]=010的MMC/SD Boot,以及BTSEL[2:0]=101的SPI Boot等。


Nand Boot Mode是DM365的一种常见启动方式,但因为处理器的AIRAM空间有限且NAND Flash不支持XIP(执行-in-place)技术,因此需要经过三个阶段的代码来完成从NAND Flash引导启动操作系统。
这一流程包括了初始化硬件、加载用户引导加载器(UBoot)到内存以及执行UBoot。


User Bootloader是DM365启动过程中的关键部分,其源码主要位于PSP包的board_utilities/flash_utils目录下。
入门代码由汇编文件start.S开始,负责切换操作模式、建立堆栈,并跳转到main函数。
在main函数中,LOCAL_boot函数负责实际的引导功能,包括调用Device_init()和NANDBOOT_copy()。


Device_init()函数完成了平台的底层初始化,如电源域、时钟、DDR、EMIF、UART、I2C和TIMER等模块的设置。
它首先屏蔽和清除中断,然后通过调用DEVICE_PSCInit启用各模块的电源和时钟,接着配置PINMUX,设置PLL1,配置DDR控制器,EMIF模块,串口0,TIMER0和I2C控制器。


当检测到启动模式配置寄存器(BOOTCFG)的BTSEL[2:0]为000时,系统将调用NAND_init()初始化NAND Flash,并通过NANDBOOT_copy()将紧随其后的Bootloader代码复制到DDR2内存中,以便于后续的程序执行。


Bootloader是嵌入式系统的重要组成部分,它的主要任务是为操作系统提供加载环境。
Bootloader的特点包括:早期系统初始化、设备驱动加载、引导操作系统、支持交互式操作等。
根据工作模式,Bootloader可以分为固件阶段和加载阶段,前者主要负责硬件初始化,后者则负责加载操作系统映像。


DM365的启动过程涉及到硬件配置、软件加载和系统初始化等多个环节,对开发人员理解和优化系统性能具有深远的影响。
了解这些知识,可以帮助我们更好地理解和调试基于DM365的系统,提高其稳定性和效率。
2025/5/20 13:14:23 530KB
1
《ICETEK-DM365-KBE-V3原理图详解》ICETEK-DM365-KBE-V3是一款由北京瑞泰公司推出的开发板,其设计基于DM365芯片,这款芯片是德州仪器(TexasInstruments,TI)生产的高性能数字媒体处理器,广泛应用于高清视频处理和多媒体应用领域。
本文将对ICETEK-DM365-KBE-V3的原理图进行详细解析。
DM365芯片的核心部分包括多个接口和信号线,如UART1(通用异步接收发送器)、I2C(Inter-IntegratedCircuit)总线、GPIO(GeneralPurposeInput/Output)引脚等。
UART1_RXD和UART1_TXD分别代表串行通信的接收和发送引脚,用于实现与外部设备的数据传输。
I2C_SDA和I2C_SCL则是I2C总线的时钟和数据线,用于控制和通信I2C兼容的外围设备。
在GPIO部分,我们可以看到EM_BA0到EM_A7等一系列引脚,它们可以作为通用输入输出使用,根据应用需求配置为输入或输出,以连接各种外设。
此外,还有SD1和SD0两个独立的SD卡接口,它们包含CLK(时钟)、CMD(命令)、D0至D3的数据线,用于支持存储扩展。
DM365还集成了McBSP(MultichannelBufferedSerialPort)接口,这是TI的多通道缓冲串行端口,用于音频和语音数据传输。
McBSP_FSR、McBSP_CLKR、McBSP_DR等引脚构成接收通道,而McBSP_FSX、McBSP_CLKX、McBSP_DX则构成发送通道,提供灵活的音频接口能力。
此外,DM365开发板上还包括了以太网PHY(物理层)接口,如TX_EN、TX_CLK、TX_D0至TX_D3、RX_D0至RX_D3等,这些接口负责处理以太网的物理层传输,确保网络数据的稳定传输。
同时,PHY接口还包含了RX_CLK、RX_DV、RX_ER等,用于接收端的数据同步和错误检测。
电源管理方面,开发板上有多个电压等级的电源引脚,如VCC_5V、VCC_3.3V、VCC_1V8等,以满足不同组件的供电需求。
同时,电路中还包含了电容C12、C18、C15、C27等,用于滤波和稳定电压。
开发板上还提供了多种视频输入和输出接口,如VIDEO_IN、VIDEO3S、VIDEO4,以及相关的同步信号如VOUT_HSYNC、VOUT_VSYNC、VOUT_LCD_OE、VOUT_VCLK等,支持不同的视频源和显示设备。
此外,还有音频接口如DAC_1_G、DAC_2_B、DAC_3_R,以及麦克风输入MIPI_CSI,满足多媒体应用的需求。
ICETEK-DM365-KBE-V3开发板具有丰富的接口和功能,集成了DM365芯片的多媒体处理能力,为开发者提供了强大的硬件平台,适用于高清视频处理、音频处理、网络通信等多种应用场景。
通过深入理解其原理图,开发者可以更好地利用该开发板进行产品设计和开发。
2025/5/20 8:13:33 53KB DM365
1
自己编写的基于粒子滤波的TBD在一个目标的仿真的算法,供大家进行参考~~~
2025/5/19 18:15:30 4KB TBD 检测前跟踪
1
基于MATLAB三比值法的电力变压器故障检测
2025/5/19 11:57:49 914B 三比值 MATLAB
1
摘要苹果叶片直接反应着苹果生长期的营养状况。
中国是苹果的主要生产国,然而国内苹果标准叶片数据的收集仅限于个别时期、个别品种的简单记录,没有形成完整且全面反应本国苹果标准叶片情况的数据集。
因此,构建不同品种苹果标准叶片的图像及近红外光谱数据集显得尤为重要。
这些数据不仅为苹果叶片分析提供参考,还为研究叶片营养快速检测技术提供数据基础。
通过收集中国苹果资源圃中种植的170余种品种的苹果标准树叶,并对叶片进行高清图像采集和近红外光谱采集,建立一个品种全面的苹果标准叶片的图像和光谱数据集。
以期为苹果叶片快速检测和精准养分管理提供数据支撑。
2025/5/18 9:09:45 4KB
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡