技术标签: 汽车产品研发
- 1、RAM Block data
RAM状态转换说明
1)上电最初状态:UNINITIALIZED
2)初始化后(NvM_Init):INVALID / UNCHANGED
3)NvM_ReadAll后更新:VALID/UNCHANGED,在这种状态下,WriteAll是不允许的
4)调用NvM_SetRamBlockStatus()可以设置RAM状态:
参数为true, VALID / CHANGED
参数为false,INVALID / UNCHANGED
5)出现CRC错误:INVALID
6)通过隐式或显式错误恢复机制改变,恢复之后:VALID / CHANGED,此时RAM的内容与NVRAM中的内容不同
7)成功将RAM中数据复制到NVRAM中:valid/unmodified
各状态条件
1)VALID / UNCHANGED
此状态RAM块的内容与相应的NV块的内容相同,或者app应用已访问了RAM,改变还没有体现出来。
进入此状态,最少满足下面一个条件:
2)VALID / CHANGED
此状态RAM block的内容可能与相应的NV block中的内容不同。
进入此状态,最少满足下面一个条件:
3) INVALID / UNCHANGED
此状态下NV block 数据是无效的,进入此状态,最少满足下面一个条件:
- 2、调用方式
1)隐式同步
如果多个app同时使用相同的RAM block,NvM就无法保证数据的完整性,此种情况,app必须使用同步的方式访问RAM
block,同时保证在操作过程中不能有其他访问
Write requests (NvM_WriteBlock or NvM_WritePRAMBlock)
1)app将数据放在RAM中,NvM写入NV block
2)app调用NvM_WriteBlock/NvM_WritePRAMBlock 发起请求
3)在执行成功或者失败前,其他app应用不能修改此RAM block,但可以read
4)app可以通过polling方式获取请求的状态,也可以通过callback回调函数异步通知
5)操作完成后,RAM block恢复可以被修改状态
Read requests (NvM_ReadBlock or NvM_ReadPRAMBlock)
1)app将数据放在RAM中,NvM写入NV block
2)app调用 NvM_ReadBlock 发起请求
3)在执行成功或者失败前,应用app不能对RAM block进行读写
4)app 可以使用polling 去获取请求的状态,或者使用callback函数获取通知请求的结果
5)操作完成后,app可以再次读写RAM block
Restore default requests (NvM_RestoreBlockDefaults and
NvM_RestorePRAMBlockDefaults
1)app提供一个RAM block,存放从NvM模块ROM的数据
2)app调用 NvM_RestoreBlockDefaults or NvM_RestorePRAMBlockDefaults 发起请求
3)在执行成功或者失败前,应用app不能对RAM block进行读写
4)app可以通过polling方式获取请求的状态,或者可以通过callback获取请求通知
5)NvM操作完成后,ROM中的数据读取到RAM中,app可以读写
Multi block read requests (NvM_ReadAll)
1)系统启动时调用,将NVRAM Block(配置时选择在readall之间读取)中的数据读到常驻RAM当中
2)如果请求失败或者只有部分NVRAM block读取成功,NvM会将该情况报告给DEM并把error返回给BswM
3)在NvM_ReadAll执行期间,当NVRAM block处理完后,会调用单个配置的block callback函数
Multi block write requests (NvM_WriteAll)
系统关机是调用,将常驻RAM block中的修改数据写入到nvram block中,在此期间,任何swc都不能修改RAM block中的数据
Cancel Operation (NvM_CancelWriteAll)
这是一个异步请求,可以调用它来终止一个挂起的NvM_WriteAll请求,只能由BswM调用
Modification of administrative blocks
每个已配置NVRAM块的一部分,如果NVRAM block当前有一个block请求处于pending状态,app不能调用任何修改administrative block的操作,如NvM_SetDataIndex, NvM_SetBlockProtection, NvM_SetRamBlockStatus,直到pending状态结束
Normal and extended runtime preparation of NVRAM blocks
根据配置参数NvMDynamicConfiguration和NvMResistantToChangedSw不同配置,NvM在启动期间(即在处理请求NvM_ReadAll()时)的行为应该是不同的
2)显示同步
mark
3)异步调用
//NvM.c
核心函数:NvM_MainFunction()、NvM_WriteBlock()、NvM_GetErrorStatus()
- 3、Static Block ID
static block id包含在NV block header中,NvM每次写NV memory时,会将static block id一并写入。每次从NV memery中读取block数据时,NvM会对block header做检测,如果static block id不一致,则发送NVM_E_WRONG_BLOCK_ID到DEM。同时启动read error recovery
- 4、Comparing NV data in NvM
- 5、NvM与BswM的交互
如果想要获取对multiblock请求状态的变化,如readall、writeall,BswM可以通过API BswM_NvM_CurrentJobMode() 获取,也可以通过此api获取single block操作请求的状态
如NvMBswMMultiBlockJobStatusInformation==true
1)NvM不会调用已经配置的 multiblock callback
2)multiblock或者single block 操作请求,执行完或者被取消完成后,NvM会调用BswM_NvM_CurrentJobMode()获取请求的结果
3)NvM正在处理multiblock请求操作时,每开始处理一个Block时,NvM都会调用BswM_NvM_CurrentJobMode()来通知BswM当前block处于Pending状态。每结束一个block,会再次调用BswM_NvM_CurrentJobMode()来通知BswM该block 的处理结果
Block locked状态NvM的行为
1)API NvM_SetBlockLockStatus()只能由BSW调用,SWC不能通过RTE调用
2)如果API NvM_SetBlockLockStatus(blockId,XXX)的参数为true
任何请求都不能修改此blockID的block中的数据,在NvM_WriteAll过程中,其他请求如NvM_WriteBlock,
NvM_WritePRAMBlock, NvM_InvalidateNvBlock, NvM_EraseNvBlock都会被直接拒绝
NvM在下次start-up时,在处理NvM_ReadBlock或NvM_ReadPRAMBlock时,数据会从nvram block中加载
3)如果API NvM_SetBlockLockStatus(blockId,XXX)的参数为false,此nvram block可以被NvM正常调用
文章浏览阅读963次。/tmp/ccvTv2zi.o: In function `av_make_error_string':encode_video.c:(.text+0x24): undefined reference to `av_strerror'/tmp/ccvTv2zi.o: In function `encode':encode_video.c:(.text+0x79): undefined reference to `avcodec_send_frame'encode_video.c:(.text+0xc_makefile 使用ffmpeg -l
文章浏览阅读4.8k次。创建tag$ git tag -a v0.1.0 -m “release 0.1.0 version”解释:创建附注标签时,参数-a即annotated的缩写,指定标签类型,后附标签名。参数m指定标签说明,说明信息会保存在标签对象中。查看tag列出当前仓库的所有标签$ git tag切换tag切换标签与切换分支命令相同$ git checkout [tagname]解..._git tag 参数
文章浏览阅读215次。已经很久没有写过博客了,期间也只是断断续续的写过两三篇最近比较的烦躁,可能是因为在家里待久了把因为每天基本上没有在学习,所以感觉自己的生活过的不是很充实有时候真的感觉自己很颓废。这两天开始学习那个微信小程序,在看那个官网的开发文档,感觉还挺不错的以后有时间尽量每天都来写一篇感悟今日心得体会和学习收获的博客吧,字数不在多认清自己在进步就好。..._2018 写博客的地方
文章浏览阅读3.7k次。想要监听页面滚动是否触底,你要先搞清offsetHeight,scrollTop,scrollHeight区别,以及如何让应用,话不多说上代码????????offsetHeight: 它是包括padding、border、水平滚动条,但不包括margin的元素的高度。️:对于行内元素这个属性值一直是0,单位px,是只读元素。scrollTop:表示在有滚动条时,滚动条向下滚动的距离也就是元素顶部被遮住部分的高度即“卷”起来的高度。️:在无滚动条时scrollTop==0恒成立,单位_vue scrollheight
文章浏览阅读1w次。关于kettle 写入mysql 遇到一个问题:LOAD_TEMP - Unable to get database metadata from this database connection,报错大致如下:2021/11/26 14:05:12 - LOAD_TEMP - ERROR (version 5.3.0.0-213, build 1 from 2015-02-02_12-17-08 by buildguy) : org.pentaho.di.core.exception.KettleDa_unable to get database metadata from this database connection
文章浏览阅读935次。XPath简介XPath 是一门在 XML 文档中查找信息的语言。XPath 用于在 XML 文档中通过元素和属性进行导航什么是 XPath?XPath 使用路径表达式在 XML 文档中进行导航XPath 包含一个标准函数库XPath 是 XSLT 中的主要元素XPath 是一个 W3C 标准XPath 路径表达式XPath 使用路径表达式来选取 XML 文档中的节点或者节点集。这些路径表达式和我们在常规的电脑文件系统中看到的表达式非常相似。XPath 标准函数XPath 含有超过 _如何定义xpath
文章浏览阅读5.9k次,点赞9次,收藏63次。一、求解目标,范围是 [1, 2],函数的图像如下所示,目的是找到该函数在这个区间的最小值。二、遗传算法(GA, Genetic Algorithm)遗传算法的步骤就是首先对个体(染色体)进行二进制编码(十进制转二进制),设置成 0 1 编码的形式,目的是后续操作方便,然后随机产生初始的种群,设定好适应度的计算函数(也就是你要优化的函数)并计算每个个体适应度,然后采用轮盘赌算法(说的高大上,其实就是把适应度进行归一化当做选择的概率)进行选择操作,之后就随机设置个体两两配对就是交叉操作,再随机_粒子群算法求x(1,2)最小值
文章浏览阅读230次。主要知识点, 修改IK分词器源码来基于mysql热更新词库 一、IK增加新词的原因 在第32小节中学习到了直接在es的词库中增加词语,来扩充自已的词库,但是这样做有以下缺点: (1)每次添加完,都要重启es才能生效,非常麻烦 (2)es是分布式的,可能有数百个节点,你不能每次都一个一个节点上面去修改 这一小节来学习让es不停机,直接在外部..._32ik
文章浏览阅读1.2k次。亲自安装1 git download dcnv2网址:下载2 打开vs2153 cd 到dcn2下载的路径在窗口运行python setup build develop注意:torch 1.8的环境失败,本人试的是torch1.3_win10 dcnv2安装
文章浏览阅读10w+次,点赞235次,收藏993次。最近需要测试产品中的REST API,无意中发现了PostMan这个chrome插件,把玩了一下,发现postman秉承了一贯以来google工具强大,易用的特质。独乐乐不如众乐乐,特此共享出来给大伙。Postman介绍Postman是google开发的一款功能强大的网页调试与发送网页HTTP请求,并能运行测试用例的的Chrome插件。其主要功能包括:模拟各种HTTP requests从常用的_postman
文章浏览阅读2.4k次。本题要求实现两个函数,分别将读入的数据存储为单链表、将链表中所有存储了某给定值的结点删除。链表结点定义如下:struct ListNode { int data; ListNode *next;};函数接口定义:struct ListNode *readlist();struct ListNode *deletem( struct ListNode *L, i..._pta带头结点的有序单链表插入及删除。
文章浏览阅读7.9k次,点赞4次,收藏12次。ORA-00031: session marked for kill 处理Oracle中杀不掉的锁最近遇到,ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放 现在提供一种方法解决这种问题,那就是在ORACLE中杀不掉的,在OS一级再杀。 1.下面的语句用来查询哪些对象被锁: SELECT S.USERNAME,S.OSUSER,S._session marked for kill