QT4.7.4Qt自定义/自绘复选框/单选框类,按钮状态有:正常状态,鼠标移动状态,鼠标按下状态,鼠标释放状态暂定为与正常状态相同。
可以设置按钮上文本或不显示文本,按钮自适应图片大小或图片自适应按钮大小,使能/禁用按钮等操作。
如果安装了QTforVS2008也可以直接使用VS2008打开,否则使用Qtcrater打开。
2025/5/25 20:02:02 7KB Qt自定义 自绘复选框 单选框类
1
2021/1/12,Win10将永久删除FlashPlayer,2021FlashPlayer永久禁用EOL,Fliqlo1.4最新版本(2021/1/12发布),无需FlashPlayer支持;
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
【ICETEK-DM365-KB-EZ试验手册】是针对基于TI DM365处理器的开发板设计的一份详细实验指南。
DM365是一款由德州仪器(Texas Instruments,简称TI)生产的高性能数字媒体处理器,适用于视频处理、音频处理以及网络应用等多种领域。
该手册的目标是帮助用户熟悉DM365开发环境,掌握基本的硬件接口操作和软件开发流程。


手册首先介绍了如何构建CCS(Code Composer Studio)仿真调试环境。
CCS是TI提供的一款集成开发环境,支持C/C++编程语言,用于开发和调试基于TI DSP的嵌入式应用程序。
实验一详细阐述了安装、配置CCS,以及创建和调试项目的基本步骤。


实验二至实验十六涵盖了从模拟信号采集(ADC实验)、网络通信(emac_loopback实验)、输入输出设备控制(按键和LED实验)到存储器操作(Nandflash和DDR实验)、时钟管理(RTC实验)、外设接口使用(如UART、USB电源、SD卡接口)等多个方面。
这些实验旨在帮助用户逐步了解DM365处理器的硬件资源和驱动程序开发。


例如,在ADC采集实验中,用户将学习如何利用DM365的内置模数转换器(ADC)获取模拟信号,并在CCS中进行数据分析。
而在emac_loopback实验中,用户会设置以太网控制器(EMAC)进行环回测试,验证网络接口功能。


视频和音频处理是DM365的重要应用领域。
实验十四的彩条输出试验展示了如何通过DM365的视频处理单元产生彩色条纹,验证视频输出功能。
实验十五和实验十六则涉及视频回放和音频播放,让用户了解如何处理多媒体数据流。


此外,手册还包含了对看门狗定时器的管理和Nandflash启动的UBL及u-boot烧写试验。
看门狗定时器是系统稳定性的重要保障,实验十一介绍了如何禁用看门狗以避免意外重启。
实验十五则涉及嵌入式系统的引导过程,通过烧写UBL和u-boot,用户可以学习如何设置DM365的启动流程。


手册最后提供了瑞泰创新公司的联系方式,该公司位于北京,可能为用户提供进一步的技术支持和服务。


这份【ICETEK-DM365-KB-EZ试验手册】是一份全面的实践教程,覆盖了DM365开发的多个关键环节,对于想要深入理解和应用DM365处理器的工程师来说,是一份宝贵的参考资料。
通过完成这些实验,用户不仅能够熟练掌握DM365的硬件特性,还能提升在嵌入式系统开发和调试方面的技能。
2025/5/20 15:54:54 5.3MB
1
TI-TMS320DM365开发板是德州仪器(TexasInstruments,简称TI)推出的一款基于高性能数字信号处理器(DSP)的评估模块(EVM),主要用于支持DM365芯片的应用开发。
DM365芯片是一款集成了视频处理能力的DSP,适用于视频监控、多媒体通信等应用领域。
本手册旨在为用户详细阐述TIDM365开发板的原理图、使用说明、跳线设置以及开发板上CPLD(复杂可编程逻辑器件)寄存器的使用方法。
在开始使用TIDM365开发板前,需要注意几个关键点。
SpectrumDigital,Inc.保留了对产品的更改和停止任何产品或服务的权利,因此建议用户获取最新版本的信息来确认数据的时效性。
SpectrumDigital,Inc.对其产品的性能和相关软件保证按照当前规格执行,但产品描述中不包含在生命支持装置、设备或系统中的使用承诺。
此外,SpectrumDigital,Inc.不承担任何关于产品在开发环境以外使用的责任,也不提供应用支持、客户产品设计、软件性能保证或本手册中涉及的专利、侵权事项。
接下来,具体介绍DM365开发板的几个关键知识点。
1.DM365原理图原理图是电子工程设计和故障排查的重要文档。
它以图形化方式展示了电路板上的所有元件及其相互连接关系。
对于DM365开发板,原理图将详尽地标明各个信号的走向,包括视频输入/输出接口、存储器接口、外围设备接口以及电源管理等关键部分。
通过原理图,开发者可以更直观地了解电路设计,从而在进行硬件调试或开发时能够快速定位问题。
2.DM365开发板详细使用说明使用说明将指导用户如何正确连接和配置开发板,包括电源连接、外围设备接口的连接以及相关跳线的设置等。
此外,使用说明还会涉及如何通过跳线进行硬件配置,比如调整时钟频率、选择不同的电源模式等,这对于确保开发板能够按照预期工作至关重要。
用户需按照使用说明书中所述步骤操作,以避免误操作导致的硬件损坏。
3.跳线使用说明跳线是简化电路板设计和调整硬件设置的一种方式。
通过将导线从一个焊盘移动到另一个焊盘,用户可以轻松地改变电路的工作模式或参数。
在DM365开发板上,跳线设置用于选择不同的I/O电平、启用或禁用某些功能,以及改变硬件的工作状态。
因此,跳线使用说明会详细介绍各个跳线的功能、位置以及如何操作,用户应仔细阅读这部分内容以保证硬件设置正确。
4.开发板CPLD寄存器使用说明CPLD是一种可以编程的逻辑芯片,它允许设计者在一定范围内对电路的逻辑功能进行定义。
DM365开发板上的CPLD可以用来实现特定的接口逻辑或者硬件加速功能。
CPLD寄存器的使用说明将指导用户如何通过编程来配置CPLD,包括加载适当的配置文件、使用编程工具以及如何通过编程接口与CPLD交互。
这部分内容对于高级用户来说特别重要,因为它们可以利用CPLD的可编程性来扩展开发板的功能或优化系统性能。
总结以上内容,TIDM365开发板是一套功能丰富的工具,它不仅提供了硬件平台,还包括详尽的文档支持,帮助开发者从原理图理解、硬件设置、到软件编程等多方面开展工作。
对于需要进行DSP开发,特别是涉及视频处理和多媒体通信的工程师来说,这款开发板提供了有力的技术支持。
然而,正如使用说明书中所强调的,开发者在使用过程中应当遵守相关的安全规范和操作指南,以保证开发工作的顺利进行,以及避免对其他无线电通信设备造成干扰。
1
众所周知,IE浏览器的性能是很差的,特别在使用诸如WebQQ2.0这样的丰富的网页应用时,你就能明显感觉到IE的内核和谷歌浏览器的webkit内核之间的性能差异了,那么有没办法提高IE的性能呢?ChromeFrame是Google推出的一个针对IE6,7,8开发的免费开源的浏览器插件,它可以让IE浏览器使用上webkit内核。
使用该插件后,用户的IE将获得和Chrome浏览器一样的高性能和丰富的功能,例如高速的Javascript引擎、支持HTML5、CSS3等新特性……用IE的壳,装上Chrome的芯ChromeFrame插件实际上就是可以让用户的浏览器外观依然是IE的菜单和界面,但当用户浏览网页时,实际上使用的是GoogleChrome浏览器的内核来对页面进行运算解析和渲染。
简单地说,就是用IE的壳,装上Chrome的芯。
IE在安装了ChromeFrame后,Acid测试达到了100分满分使用谷歌浏览器内嵌框架ChromeFrame的优势:IE6提速40倍,IE8提速10倍提高您的网页浏览速度在使用谷歌浏览器的内嵌框架后,浏览网站可获得更快的响应速度和性能。
使用更多高级功能通过谷歌浏览器内嵌框架,你的浏览器可以等到诸如HTML、CSS3等新功能的支持。
不会改变您原来的上网方式谷歌浏览器内嵌框架ChromeFrame依然使用IE的界面和菜单,不会改变你原来的上网习惯。
禁用和卸载ChromeFrame的方法:因为国内很多例如网上银行之类的应用只支持万恶的IE,当你需要禁用ChromeFrame时,只需要:1.工具-管理加载项2.在工具栏和扩展中,找到ChromeFrameBHO.3.禁用它另外,卸载ChromeFrame的话,只要在控制面板中像卸载普通软件一样卸载即可。
2025/4/30 18:09:44 30.86MB IE Chrome
1
这个来自@WZT的开源程序是用来破坏Windows7/8/8.1/10上的监视功能的,软件大小不到1M,可以彻底关闭Win10的各种隐私相关设定,完全地破坏监视功能。
禁用Windows更新,让你保持匿名并不再接收新的监视软件的更新;
禁用UAC、WindowsDefender、隐私设置、监控计划任务等等;
移除Cortana、OneDrive、遥测与数据搜集、遥测主服务、位置服务、Wi-Fi共享、广告ID、Defender数据报告、手写数据共享、DRM互联网访问、系统反馈请求、系统搜索、IE/Edge请勿跟踪、历史记录等等。
另外,删除Win10的Metro应用也是相当有用的,因为这些应用在后台运行,占用内存,其中有些也会监视你的电脑。
还有,程序也能阻止微软收集数据的IP地址,并可以添加所有监视软件的ip到HOSTS文件。
值得注意的是,程序操作的大多数部分是不可逆的,甚至系统还原也不能回退更改。
现在来说,它是相当有效的程序。
它正处在开发中,并拥有一个由Windows10的用户组成的社区。
其中一些人帮助重写代码以提高程序的高效性,另一些则将程序翻译成其他语言,包含简体中文语言等。
2025/4/19 14:04:27 65KB win10
1
svm前的数据转化,操作步骤:1.先运行FormatDataLibsvm.xls2.然后将数据粘贴到sheet1的topleft单元先将数据按照下列格式存放(注意label放最后面):value1value2„„labelvalue1value2„„label„„然后将以上数据粘贴到FormatDataLibsvm.xls中的最左上角单元格3.点击"工具"-_-"宏"-_-执行下面有一个选项(FormatDatatoLibsvm),选中然后运行即可(注意:如果你禁用了宏,请在“excel选项”中先启动宏)
2025/4/16 21:35:36 7KB FormatDataLibsvm libsvm
1
DeviceAnimationTestRule使用Espresso在Android上运行检测测试需要禁用动画。
DeviceAnimationTestRule是一个JUnit规则,可在运行任何测试之前禁用设备动画,并在执行每个测试之后启用它们。
该解决方案只是在其提出的解决方案的包装。
设置添加到顶级gradle.build文件allprojects{repositories{maven{url"https://jitpack.io"}}}添加到应用程序模块gradle.build文件dependencies{androidTestImplementation'com.github.VictorAlbertos:DeviceAnimationTestRule:0.0.3'}用法添加到Androi
2025/4/2 1:34:49 105KB Kotlin
1
共 114 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡