【ETAS CP AUTOSAR基础软件】EcuM模块详解

文章包含了AUTOSAR基础软件(BSW)中EcuM模块相关的内容详解。本文从AUTOSAR规范解析,ISOLAR-AB配置以及模块相关代码分析三个维度来帮读者清晰的认识和了解EcuM。文中涉及的SOLAR-AB配置以及模块相关代码都是依托于ETAS提供的工具链来配置与生成的,与AUTOSAR规范之间可能会有些许的出入,但总体的功能要点与处理流程都应该是一致的。

EcuM的规范中包含了休眠唤醒这部分功能,但是因为其实现与其他诸多模块耦合性较大,且唤醒源的选择与ECU的应用有很大的关系,大部分项目都选择了不在EcuM框架里实现这个功能,而是由应用层依托复杂驱动(电源管理芯片)或IoAbstraction来实现这部分功能。

目录

AUTOSAR规范解析

概述

启动阶段(STARTUP)

StartPreOS Sequence

StartPostOS Sequence 

参数一致性检查

运行阶段(UP Phase)

关闭阶段(SHUTDOWN Phase)

OffPreOS Sequence 

OffPostOS Sequence 

睡眠阶段(SLEEP Phase)

GoSleep Sequence

Halt Sequence 

Poll Sequence 

WakeupRestart Sequence

多核(MultiCore) 

ISOLAR-AB配置

EcuMGeneral 

EcuMCommonConfiguration

EcuMDefaultShutdownTarget 

EcuMDriverInitListOne

EcuMWakeupSource 

EcuMFlexConfiguration

代码解析

动态代码

集成代码

静态代码 


AUTOSAR规范解析

概述

ECU管理器模块(ECU Manager)是管理ECU状态的基础软件模块。具体来说,ECU管理器模块负责:

  • 初始化和去初始化OS、SchM和BswM以及一些基础软件驱动模块。
  • 将ECU配置为关机或者睡眠状态。
  • 管理ECU上的所有唤醒事件(wakeup events),并提供唤醒验证机制(Wakeup validation protocol),以区分真实(real)和不稳定(erratic)唤醒事件。

EcuM具有flex与fixed两种状态管理机制,fixed模式状态唯一,跳转目标状态也是固定的,而flex模式跳转状态不唯一,可自行设计。Fixed模式在4.4中被移除。下面只介绍flex模式。

灵活的EcuM(Flexible)本身不再具有自己的状态机,因为基础软件的调度管理模块已经整合进RTE模块,并提供了宽松的模式声明与不同模块间的模式切换映射,搭配上BswM提供的可配置的规则与对应的执行列表来评估并完成ECU模式切换等行为,所以大多数之前在Fixed模式下的ECU模式已经不在ECU管理器模块中实现。

通常EcuM模块接管控制早期STARTUP阶段和后期SHUTDOWN阶段以及调度被锁定的SLEEP阶段。 

EcuM在ECU启动后,经过Boot和启动代码后(非AUTOSAR标准),立刻获得核心控制权,在初始化SchM和BswM后将控制权委托给BSW模式管理器。在UP阶段ECU管理器模块会对来自SW-C的RUN和POST_RUN请求进行仲裁,并通知BswM有关的模式状态,并且会对唤醒源进行验证,并通知BswM验证结果,所有这些在UP阶段涉及的操作都是给BswM模式管理提供依据。最后在SHUTDOWN阶段,BswM在配置完ShutdownTarget后会将控制权交还给EcuM。

EcuM在SLEEP阶段配置MCU休眠状态(根据芯片支持情况,选择HALT或者POLL),并在唤醒之后与集成代码和驱动配合完成预设阶段工作之后,回到UP阶段。下图是所有阶段的示意图,注意图中的阶段只是表征当前EcuM所处阶段,并不是具体的模式,它包含一系列操作序列。


启动阶段(STARTUP)

上图显示了ECU启动阶段涉及的动态行为。在调用EcuM_Init之前,假定MCU最小系统的初始化过程已经完成(堆栈等已被设置,代码可以被正常运行)。当调用EcuM_Init时,EcuM将控制ECU启动过程。调用Startos后,ECU Manager模块将暂时放弃控制。要重新获得控制权,Integrator(集成商)可以在操作系统的StartupHook处,挂接EcuMStartupTwo作为其第一个操作,也可以起一个Task来做这件事情。

由上图可以看出,Startup阶段按照OS启动作为分水岭,可分为StartPreOS与StartPostOS两个子阶段。经历过Startup阶段之后,则会进入到UP阶段。STARTUP阶段的目的是将基础软件模块初始化到通用模式管理设施(Generic Mode Management facilities,包括BswM以及SchM等)可操作的点。


StartPreOS Sequence

下表按顺序描述了StartPreOS Sequence涉及的动作。

  1. 调用EcuM_AL_SetProgrammableInterrupts:EcuM_AL_SetProgrammableInterrupts函数由集成商实现在EcuM_Callout_Stubs.c模板文件(模板文件只有函数名定义,函数体为空)中,在具有可编程中断优先级的ECU上,启动OS之前完成这些优先级的设置。
  2. 调用EcuM_AL_DriverInitZero:根据集成商在ISOLAR中的配置,EcuM_AL_DriverInitZero函数生成在EcuM_Cfg_Startup.c文件中,此初始化列表应包含不使用post-build参数的低级BSW模块与MCAL驱动。
  3. 调用EcuM_DeterminePbConfiguration:EcuM_DeterminePbConfiguration集成商实现在EcuM_Callout_Stubs.c文件中,仅在使用了post-build参数可选特性被使用的时候,用户可在ISOLAR中配置根据对应Pin高低状态来选择,若没有则生成的EcuM_Callout_Stubs.c模板文件会默认返回EcuM_EcuMConfigurations_cpcast[0]。
  4. Check consistency of configuration data:检查pre-compile与link-time的参数与post-build参数之间的依赖性,保证ECU Code Image与ECU Post-Build Data Image之间的一致性。如果检验失败则EcuM_ErrorHook调用。
  5. EcuM_AL_DriverInitOne:包含了在启动OS之前必要的驱动初始化列表,集成商在ISOLAR中进行配置,代码生成在EcuM_Cfg_Startup.c文件中。
  6. Get reset reason:调用MCU驱动模块提供的Mcu_GetResetReason获取重启原因,并根据在ISOLAR中配置的ECU唤醒源与重启原因的对应关系,调用EcuM_SetWakeupEvent设置对应的唤醒事件。
  7. Select default shutdown target:根据ISOLAR中配置的EcuMDefaultState以及对应的reset或sleep mode来完成默认关闭阶段的配置(off则无mode)。
  8. EcuM_LoopDetection:如果循环检测使能,将会在每次启动阶段调用EcuM_LoopDetection,函数模板在EcuM_Callout_Stubs.c中,由集成商实现具体内容。
  9. Start OS:启动操作系统。


StartPostOS Sequence 

下表按顺序描述了StartPostOS Sequence涉及的动作。

  1. Start BSW Scheduler:启动基础软件调度模块,现在这个模块已经融入到RTE,不用再单独启动。
  2. Init BSW Mode Manager:初始化BswM模块。
  3. Init BSW Scheduler:调用SchM_Init()完成初始状态的配置通知。
  4. Start Scheduler Timing:因为基础软件调度模块已于RTE合并,此处不在单独启动。
  5. BswM_MainFunction:调度BswM的主处理函数,完成BSW后续的基础软件初始化以及GPT定时器启动,最终OS正常开始调度任务。


参数一致性检查

AUTOSAR将配置按照固件生成的过程分为了三类,Precompile、Linktime以及PostBuild。这三类比较重要的就是PostBuild类配置,这类配置可以单独放到一个存储区域,这个区域可以被单独刷写(通过Flash擦写工具,通过UDS服务),这样做的好处就是OEM不需要知道具体的代码逻辑,也不需要编译器(某些编译器需要license才能使用),也能修改BSW涉及的部分参数。

一级供应商的可以使用通过两个工具,分别开发配置完后,再用编译器,编译链接,生成HEX文件。OEM使用配置工具完成PostBuild参数的配置,然后通过Post Build Tool生成二进制文件,单独将这个二进制文件更新到特定的存储区域(例如上图中的ECU Post Build Data Image写入地址0x8000_0000中)。

这个时候就需要验证单独更新的这部分参数是否与其余的参数是配套的,如果不配套则会出现很多意想不到的问题,AUTOSAR的方式是对Precompile、Linktime进行哈希算法得到一个例如MD5值,并将这个值写于PostBuild参数中,这样就可以在代码运行时从PostBuild参数中拿出这个MD5值与上图中的ECU Code Image中的MD5值相对比。


运行阶段(UP Phase)

在运行阶段,ECU的状态由BswM来控制,EcuM_MainFunction会定期执行,完成下面三个任务。

  • 检查唤醒源是否被唤醒,并将唤醒源的状态通知其他模块,并在必要时启动唤醒验证。
  • 更新闹钟定时器(Alarm Clock timer)。
  • 仲裁RUN和POST_RUN的请求和释放。

当闹钟服务存在时,EcuM_MainFunction主功能将更新闹钟定时器,这里主要针对在Sleep模式下进行定时唤醒功能的实现,在EcuM框架下实现这个功能很少,这里就不赘述了。

下图为唤醒验证过程,看起来比较复杂,下图的动态流程以Can模块为唤醒源,集成代码负责重新启动和停止CAN模块唤醒功能(特定帧或别的判决唤醒方式),唤醒源存在之后会告知EcuM,并通知ComM与BswM存在验证过的唤醒源,如果超时了也没有,则通知BswM唤醒源现在为废弃的状态。

EcuM用一种数据类型定义了所有的启动和唤醒源,我们统一称为唤醒源。下面这五种唤醒源为ISOLAR自动配置的,并不会触发验证过程,直接。

  • ECUM_WKSOURCE_POWER
  • ECUM_WKSOURCE_RESET
  • ECUM_WKSOURCE_INTERNAL_RESET
  • ECUM_WKSOURCE_INTERNAL_WDG
  • ECUM_WKSOURCE_EXTERNAL_WDG

ECU状态管理器为SW-C提供接口以请求和释放RUN模式和可选的POST_RUN模式。在ECUM_CFG_MODE_HANDLING==STD_ON时,EcuMFlex对SW-C发出的请求和释放进行仲裁,并将结果传送给BswM。因为只有BswM可以决定何时可以转换到不同的模式,所以EcuM和BswM之间的合作是必需的。外EcuM将当前请求的仲裁通知BswM。

现在的状态管理都放到了BswM里,什么时候要进入睡眠状态已经由应用程序决定了,所以唤醒源的验证以及对RUN和POST_RUN的仲裁已经不常用了。


关闭阶段(SHUTDOWN Phase)

这个阶段出现在调用EcuM_GoDown()之后,Ecum首先检验当前的ShutdownTarget是否为ECUM_SHUTDOWN_TARGET_OFF或者ECUM_SHUTDOWN_TARGET_RESET,如果是才正式修改GoDown的全局变量,EcuM_MainFunction会根据此全局变量执行对应的关闭阶段行为,ISOLAR会根据AUTOSAR默认创建三个重启模式,如果ShutdownTarget选择ECUM_SHUTDOWN_TARGET_RESET的话可以配置选择对应模式,并在关闭阶段根据对应模式自定义一些行为。

  • ECUM_RESET_MCU
  • ECUM_RESET_WDGM
  • ECUM_RESET_IO


OffPreOS Sequence 

下表按顺序描述了OffPreOS Sequence涉及的动作。

  1. De-init BSW Mode Manager:取消BswM初始化(BswM_Deinit)。
  2. De-init BSW Scheduler:取消基础软件调度初始化(SchM_Deinit)。
  3. Check for pending wakeup events:目的是检测关机期间发生的唤醒事件。
  4. 如果唤醒事件挂起,设置RESET为shutdown target:只有当检测到挂起的唤醒事件允许立即启动时,才应执行此操作(这块在ETAS生成的静态代码里没有看到体现)。
  5. ShutdownOS:关闭OS。


OffPostOS Sequence 

OffPostOs序列实现了在操作系统关闭后达到关闭目标的最后步骤。EcuM_Shutdown()启动该序列,其挂接在Os的回调函数Os_Cbk_InShutdown()。ShutdownTarget可以是ECUM_SHUTDOWN_TARGET_RESET或ECUM_SHUTDOWN_TARGET_OFF,其中具体的复位模式由ShutdownModeType决定,默认ISOLAR会创建上文提到的ECUM_RESET_MCU等三种模式。

下表按顺序描述了OffPostOS Sequence涉及的动作。

  1. 调用EcuM_OnGoOffTwo:集成商自定义的动作。
  2. 调用EcuM_AL_Reset 或者 EcuM_AL_SwitchOff:取决于所选择的ShutdownTarget(RESET or OFF)


睡眠阶段(SLEEP Phase)

ECU在SLEEP阶段整个板卡处于低功耗(saves energy)状态。不同的微控制器对低功耗模式有不同的实现,最常见的实现为核心不执行任何代码,在核心进入这种模式之前,通过配置相应的唤醒中断(IO口电平转换或者定时器超时)会将核心唤醒,这种模式可以使用ECU管理器模块提供的Halt睡眠模式。

还有另外一种,例如瑞萨平台,它的低功耗模式(STOP)是可以执行代码的,Mcu_SetMode (MCU_STOP_MODE)进入低功耗模式之后可以轮询检测各个IO口状态,状态变化之后可以离开这种模式,这种模式可以使用ECU管理器模块提供的Polling睡眠模式。

还有一种外围芯片(电源芯片和CAN收发器配合)完成休眠唤醒的方式,微控制芯片可以通过不喂狗等方式使电源芯片停止对微控制器供电,此时休眠,微控制器直接掉电了,但是CAN收发器还有供电,在满足唤醒要求(接收到特定帧等情况),它会通过自己的INH引脚反映到电源管理芯片上的WAKE引脚,上升沿来重启电源管理芯片。

规范里使用SLEEP作为ShutdownTarget时,EcuM_GoDownHaltPoll函数会启动两种控制流。具体哪种控制流取决于EcuMSleepMode参数所配置的睡眠模式。但实际在ETAS的静态代码里,两种不同的流程调用的分别是EcuM_GoHalt和GotPoll,在关闭时也是直接调用EcuM_GoDown。Poll和Halt在实现睡眠的机制上的结构是不同(Poll需要主动轮询中断源,Halt则被中断启动核心)。但是它们在准备睡眠和从睡眠恢复过程的顺序却是相同的。


GoSleep Sequence

在GoSleep的序列中,ECU管理器模块需为即将到来的睡眠阶段进行相关的硬件配置,ECU管理器模块为了后续的睡眠模式,需进行唤醒源的配置。ECU管理器模块调用EcuM_EnableWakeupSources(),然后集成商会依次为每个在EcuM_WakeupSource中配置的唤醒源执行相关的设置工作。与SHUTDOWN阶段相比,ECU管理器模块在进入SLEEP阶段时,不应关闭操作系统。


Halt Sequence 

下图是暂停阶段EcuM涉及的动态行为,这里边EcuM主要完成与操作系统的交互(开关中断)和MCU模式切换,并在最后将唤醒源事件汇报给BswM。

集成代码需要实现两个主要的函数,一个是EcuM_CheckWakeUp(),其实这个函数的名字主要是因为在Poll模式下需要不断轮询唤醒源,在Halt模式下成为了使能PLL等操作,另一个是一对函数,在睡眠之前调用EcuM_GenerateRamHash()对RAM区计算一个Hash值,等唤醒之后再调用EcuM_CheckRamHash(uint8)确保RAM区在睡眠过程中没有发生意外的变化。

中断源最后还要通过EcuM_SetWakeupEvent()告诉EcuM中断源事件已经出现。


Poll Sequence 

这个动作序列跟Halt序列相比,集成代码增加了EcuM_SleepActivity()的实现,在睡眠的时候可以执行一些代码,并在EcuM_CheckWakeup(EcuM_WakeupSourceType)轮询查找是否有唤醒源触发了。


WakeupRestart Sequence

下表按顺序描述了WakeupRestart Sequence涉及的动作。

  1. Restore MCU normal mode:恢复参数EcuMNormalMcuModeRef定义的MCU模式。
  2. Get the pending wakeup sources:获取当前已触发但是未验证的唤醒源。
  3. 调用EcuM_DisableWakeupSources:禁用进入睡眠模式之前使能的唤醒源。
  4. 调用EcuM_AL_DriverRestart:重写初始化一些睡眠会影响的外设。
  5. Unlock Scheduler:到此节点,所有其他任务可能会再次运行。


多核(MultiCore) 

BSW模块在不同分区上(partition)的分布。分区(partition)可以被看作是映射在一个内核(core)上的独立部分。所以每个核(无论是单核架构还是多核架构)都至少包含一个,但也可以包含任意多个分区。但是任何分区都不能跨越一个以上的内核。

BswM这类的BSW模块需包含在每个分区中,但是如OS或EcuM这类的其他模块需包含在每个内核的一个分区中。具体示例请参考下图。即EcuM在每个核需要存在一个实例。

引导加载程序(boot loader)指定的主内核通过EcuM_Init启动主EcuM(master EcuM)。 主EcuM负责启动一些驱动程序,确定Post Build配置,接着启动其他的内核及其所附属EcuM(Satellite EcuMs), 其他内核的EcuM完成启动本核心附属的OS和BswM。

ECU管理器模块在多核ECU上支持与传统ECU上相同的阶段(即:STARTUP、UP、SHUTDOWN和SLEEP)。但是每个阶段都因其是在主核还是其他核心部署而行为有所不同,EcuM会通过GetCoreID获取核心ID来判断自己是否身处在主核,如果是主核心则跟完成跟单核类似的阶段活动,如果有必要需要在开始的时候通过OS提供的资源或者任务来启动其他核心这个阶段的活动,其他核心的阶段活动一般都为阉割版本,进处理本核心相关的一些组件,主核这个阶段最后往往还需要等待所有从核完成对应阶段的活动,才算完成了整个阶段。下面是一个关闭阶段的实例,可以看到在主核部署的EcuM核从核部署的EcuM之间配合的过程。


ISOLAR-AB配置

因为选择的是外围芯片(电源管理芯片与CAN芯片配合)完成休眠唤醒的工作,并且因为休眠是直接相当于直接断了微控制器的电,所以一些不同模式切换引发的驱动和存储区状态不确定的问题也不需要进行特殊处理,所以休眠唤醒相关的完整流程可以比较轻松的在应用层完成实现。

下面是完整的相关配置项。


EcuMGeneral 

该容器一般包含一些预编译配置参数,如果您在ISOLAR-AB选中要配置的参数,在Quick Info窗口会显示该参数的描述,如下图所示。如果您有的时候发现描述和规范里说明有所出入,那么这很正常,因为规范是规范,而ISOLAR-AB是对规范的实现,难免会有所出入。

所以我这边就不采用地毯式的把所有参数的介绍都翻译一遍了,我们只挑一些重要的配置进行说明。

  • EcuMIncludeDet: 如果为真,初始化对应的BSW模块。
  • EcuMRbRunMinimumDuration:持续时间以秒为单位。如果将其配置为非零值,则在启动后,即使没有任何用户的运行请求,EcuM也将继续保持在RUN状态。在配置此值时,Integrator应该参考Rte启动的时间来配置。
  • EcuMMainFunctionPerio:主函数EcuM_MainFunction调用周期,现在的基础软件主函数都映射到了Task里了。
  • EcuMRbSlaveCoreEarlyStart:如果此参数设置为TRUE。从内核会更早地启动,比如从内核将在初始化EcuMDriverlnitListOne之前由master启动。如果该参数设置为FALSE,则在EcuM_Init的结束阶段启动Slave内核。
  • EcuMRbNvMBlockDeviceld:命名为ECUM_CFG_NVM_block的NVRAM块所在设备的标识。当配置了NvM模块时,该块在CodeGen期间转发给NvM。设备ID为0固定为地址Fee,设备ID 为1固定为地址Eep设备。如果不配置,则默认转发设备ID为0。
  • EcuMRbIncludeHeaderList:自定义头文件列表,它将包含在EcuM.h中。
  • XXXXXXXXCallout:EcuM中的调用函数,可以配置调用的函数名和其他内容,用于生成在EcuM_Callout中函数的实现,用户也可以在EcuM_Callout_Stubs.c模板文件中手动添加逻辑。

EcuMCommonConfiguration

EcuMDefaultAppMode:ECU复位后加载的默认操作系统应用模式。


EcuMDefaultShutdownTarget 

EcuMDefaultState:该参数描述ECU默认shutdowntarget。即OFF或RESET或SLEEP。如果选择了重启或者是睡眠,则参数EcuMDefaultResetModeRef将选择具体的模式。 


EcuMDriverInitListOne

  • EcuMModuleID:要初始化的模块的短名称,例如Mcu, Gpt等。
  • EcuMModuleParameter:定义函数原型和传递给函数的参数。如果EcuM模块参数“POSTBUILD”,然后EcuM将调用MCU_lnit(&Mcu_Config),MCAL生成的静态代码的模块初始化函数名可以保证,但是参数名称往往不是Mcu_Config,需要利用刚才提到的EcuMRbIncludeHeaderList配置包含一个头文件,完成MCAL模块参数结构体的映射。
    /* EcuM Initialization */
    #define Mcu_Config	              Mcu_ConfigRoot[0]
    /* BswM Initialization */

EcuMWakeupSource 

系统默认配置的五个唤醒源。

  • EcuMValidationTimeout:验证超时(ECU状态管理器等待唤醒事件验证的时间)可以为每个唤醒源独立定义。超时时间以主函数周期为单位指定。如果没有配置这个超时,那么这个唤醒源就不会有任何验证例程,EcuM会立即认为这个源是有效的。
  •  EcuMComMChannelRef:该参数是对通信管理器中定义的网络(通道)的引用,不引用表示唤醒源不是通信通道。如果配置了此引用,则唤醒源检测将指示给ComM。
  • EcuMResetReasonRef:该参数描述MCU驱动检测到的复位原因到唤醒源的映射。在EcuM初始化期间需要此映射来检查上次重置原因。
  • EcuMComMPNCRef:这是对通信管理器中定义的一个或多个PNC的引用。没有引用表示唤醒源没有分配给部分网络。

EcuMFlexConfiguration

  • EcuMFlexUserConfig:用户序号定义。
  • EcuMGoDownAllowedUsers:允许使用GoDown接口关闭ECU的用户,引用EcuMFlexUserConfig。
  • EcuMResetMode:这些容器描述了重置模式的。3种复位模式是标准的,
    这是由EcuM自动配置的。
  • EcuMShutdownCause:这些容器描述了配置的Shutdown原因。这三种关闭原因是默认的,由EcuM自动配置。

代码解析

动态代码

我们下面挑几个常用的进行内容说明。

  • EcuM_PBcfg.c:包含Post Build配置EcuM_Config结构体,主要启动OS需要的AppMode,关闭阶段用到的shutdowntarget,MCAL初始化模块的参数指针,以及验证一致性用到的Hash值等。结构体原型如下,注释体现了对应包含的内容。
    typedef struct
    {AppModeType DefaultAppMode;EcuM_ShutdownTargetInfoType DefaultShutdownTarget; /*Structure to hold the Default Shutdown Target*/EcuM_Cfg_adrModuleInitRef_t ModuleInitPtrPB; /*Structure to hold the post build configuration pointer of the modules*/const EcuM_Cfg_dataWkupPNCRefStruct_tst *adrWkupPNCRefs; /* Pointer to the PNC references associated with Wakeups */uint8 PostBuildHash[ECUM_CFG_LENGTH_OF_HASH];
    } EcuM_ConfigType;
  • EcuM_Lcfg.c:包含EcuM_Cfg_dataPreCompileHash_au8参数,链接参数的Hash值,用于与PB参数中的Hash值比较。
  • EcuM_Cfg.c:包含EcuM_Cfg_idxWakeupSourcesPC_au32等常量配置。
    CONST( EcuM_Cfg_dataWkupSrcStruct_tst,  ECUM_CONST)  EcuM_Cfg_idxWakeupSourcesPC_au32[ECUM_NUM_OF_WKP_SOURCES] =
    {/*IsComChannelPresent,       ComChannelReferance,                     ResetReason,             ValidationTimeout,   IsWakeupSourcePolling,                WakeupSourceId                         */
    {      FALSE          ,       255                                   ,  MCU_RESET_UNDEFINED   ,         0         ,        FALSE  ,              EcuMConf_EcuMWakeupSource_ECUM_WKSOURCE_POWER},
    {      FALSE          ,       255                                   ,  MCU_RESET_UNDEFINED   ,         0         ,        FALSE  ,              EcuMConf_EcuMWakeupSource_ECUM_WKSOURCE_RESET},
    {      FALSE          ,       255                                   ,  MCU_RESET_UNDEFINED   ,         0         ,        FALSE  ,              EcuMConf_EcuMWakeupSource_ECUM_WKSOURCE_INTERNAL_RESET},
    {      FALSE          ,       255                                   ,  MCU_RESET_UNDEFINED   ,         0         ,        FALSE  ,              EcuMConf_EcuMWakeupSource_ECUM_WKSOURCE_INTERNAL_WDG},
    {      FALSE          ,       255                                   ,  MCU_RESET_UNDEFINED   ,         0         ,        FALSE  ,              EcuMConf_EcuMWakeupSource_ECUM_WKSOURCE_EXTERNAL_WDG}
    };
  • EcuM_Cfg.h:包含一些宏定义预编译配置。
    #define	ECUM_VERSION_INFO_API	(STD_ON)#define ECUM_DEV_ERROR_DETECT 	(STD_ON) #define ECUM_INCLUDE_DET (STD_ON)#define ECUM_CFG_MULTICORE_ENABLED	(STD_OFF)/* If ECUM_CFG_MODE_HANDLING is STD_ON then All the Mode management APi's and Run handling protocol will be enabled*/
    #define ECUM_CFG_MODE_HANDLING  (STD_OFF)
  • EcuM_Cfg_Startup.c:EcuM_AL_DriverInitZero()与EcuM_AL_DriverInitOne()实现,在EcuM_AL_DriverInitOne初始化上述定义的MCU模块。

集成代码

我们这里就不描述通用的SchM.h以及MemMap.h以及CompilerSpecific.h头文件。主要看一下EcuM_Callout_Stubs.c文件,下面是完整的默认模板文件,集成商可以在其添加自己的处理逻辑。

/** This is a template file. It defines integration functions necessary to complete RTA-BSW.* The integrator must complete the templates before deploying software containing functions defined in this file.* Once templates have been completed, the integrator should delete the #error line.* Note: The integrator is responsible for updates made to this file.** To remove the following error define the macro NOT_READY_FOR_TESTING_OR_DEPLOYMENT with a compiler option (e.g. -D NOT_READY_FOR_TESTING_OR_DEPLOYMENT)* The removal of the error only allows the user to proceed with the building phase*/
#ifndef NOT_READY_FOR_TESTING_OR_DEPLOYMENT
#error The content of this file is a template which provides empty stubs. The content of this file must be completed by the integrator accordingly to project specific requirements
#else
#warning The content of this file is a template which provides empty stubs. The content of this file must be completed by the integrator accordingly to project specific requirements
#endif /* NOT_READY_FOR_TESTING_OR_DEPLOYMENT *//**********************************************************************************************************************
* CONTAINS THE STUBS OF THE CALLOUTS REALIZED IN THE IMPLEMENTATION
*********************************************************************************************************************//**************************************************************************************************** Includes***************************************************************************************************/#include "EcuM.h" /*BSW_HeaderInc_002*/#include "EcuM_Callout.h"#include "EcuM_RunTime.h" /*For init callout duration measurement*/#include "EcuM_Prv.h"/* External Header Include */
#include "Os.h"
#if (ECUM_CFG_NVM_BLOCK_CONFIGURED == TRUE)
#include "NvM.h"                    /*for setramblockstatus api*/
#if (!defined(NVM_AR_RELEASE_MAJOR_VERSION) || (NVM_AR_RELEASE_MAJOR_VERSION != 4))
#error "AUTOSAR major version undefined or mismatched"
#endif
#if (!defined(NVM_AR_RELEASE_MINOR_VERSION) || (NVM_AR_RELEASE_MINOR_VERSION != 2))
#error "AUTOSAR minor version undefined or mismatched"
#endif
#endif//ECUM_CFG_NVM_BLOCK_CONFIGURED#define ECUM_START_SEC_VAR_CLEARED_BOOLEAN
#include "EcuM_Cfg_MemMap.h"/*If EcuM_OnGoOffOne() is not added via configuration then* hard coded callout stub will be enabled */
#ifndef ECUM_CFG_ON_GOOFFONE
/*Variable used to check,whether the execution reached the EcuM_OnGoOffOne() callout.*/
static volatile boolean EcuM_IsOnGoOffOneReached_b;
#endif/*If EcuM_OnGoOffTwo() is not added via configuration then* hard coded callout stub will be enabled */
#ifndef ECUM_CFG_ON_GOOFFTWO
/*Variable used to check,whether the execution reached the EcuM_OnGoOffTwo() callout.*/
static volatile boolean EcuM_IsOnGoOffTwoReached_b;
#endif/*If EcuM_AL_SwitchOff() is not added via configuration then* hard coded callout stub will be enabled */
#ifndef ECUM_CFG_AL_SWITCHOFF
/*Variable used to check,whether the execution reached the EcuM_AL_SwitchOff() callout.*/
static volatile boolean EcuM_IsALSwitchOffReached_b;
#endif#define ECUM_STOP_SEC_VAR_CLEARED_BOOLEAN
#include "EcuM_Cfg_MemMap.h"#ifndef ECUM_CFG_ON_GOOFFTWO
#if (ECUM_STARTUP_DURATION == TRUE) /*will activate the Run time measurement*/#define ECUM_START_SEC_VAR_CLEARED_32
#include "EcuM_Cfg_MemMap.h"
/*To store the time taken for shutdown / reset*/
VAR( uint32, ECUM_VAR_CLEARED_32 ) EcuM_Shutdown_delta_us_u32;
#define ECUM_STOP_SEC_VAR_CLEARED_32
#include "EcuM_Cfg_MemMap.h"#define ECUM_START_SEC_VAR_CLEARED_UNSPECIFIED
#include "EcuM_Cfg_MemMap.h"
VAR( EcuM_TimeTicks_tu64, ECUM_VAR_CLEARED_UNSPECIFIED ) EcuM_Shutdown_begin_ticks_u64;
VAR( EcuM_TimeTicks_tu64, ECUM_VAR_CLEARED_UNSPECIFIED ) EcuM_Shutdown_end_ticks_u64;
#define ECUM_STOP_SEC_VAR_CLEARED_UNSPECIFIED
#include "EcuM_Cfg_MemMap.h"#endif//ECUM_STARTUP_DURATION
#endif//ifdef/*************************************************************************************************CALLOUTS
*************************************************************************************************/#define ECUM_START_SEC_CALLOUT_CODE
#include "EcuM_Cfg_MemMap.h"/*************************************************************************************************Function name     :   EcuM_ErrorHookDescription       :   In case of serious error conditions like consistancy check failure orRam check failure, ecuM will initiate this call. In such situations it is not possible tocontinue processing and Ecu has to be stopped.Parameter         :   Std_ReturnType reasonReturn value      :   none************************************************************************************/FUNC(void , ECUM_CALLOUT_CODE) EcuM_ErrorHook(VAR(uint16, AUTOMATIC) reason )
{while(1);
}/*************************************************************************************************Function name     :   EcuM_AL_SetProgrammableInterruptsDescription       :   EcuM_AL_SetProgrammableInterrupts shall set the interrupts on ECUs with programmableinterrupts.Parameter         :   noneReturn value      :   none************************************************************************************/
FUNC(void , ECUM_CALLOUT_CODE) EcuM_AL_SetProgrammableInterrupts(void)
{}/**********************************************************************************Function name     :   EcuM_DeterminePbConfigurationDescription       :   This callout should evaluate some condition, like port pin orNVRAM value, to determine which post-build configuration shallbe used in the remainder of the startup process. It shall loadthis configuration data into a piece of memory that is accessibleby all BSW modules and shall return a pointer to the EcuM post-buildconfiguration as a base for all BSW module post-build configrations.Parameter (in)    :   NoneParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   EcuM_ConfigType*Remarks           :
***********************************************************************************/
FUNC_P2CONST( EcuM_ConfigType , AUTOMATIC, ECUM_CALLOUT_CODE ) EcuM_DeterminePbConfiguration( void )
{
#if ECUM_STARTUP_DURATION == TRUE /*will activate the Run time measurement*/EcuM_DeterminePbConfiguration_begin_ticks_u64    =   EcuM_GetTicks();
#endif /*ECUM_STARTUP_DURATION*//* Function definition can be added here , that is in between EcuM_DeterminePbConfiguration_begin_ticks_u64* and EcuM_DeterminePbConfiguration_end_ticks_u64. By this if project can measure the time duration* of this function*/#if ECUM_STARTUP_DURATION == TRUE /*will activate the Run time measurement*/EcuM_DeterminePbConfiguration_end_ticks_u64    =   EcuM_GetTicks();
#endif /*ECUM_STARTUP_DURATION*/return(EcuM_EcuMConfigurations_cpcast[0]);
}#ifndef ECUM_CFG_ON_GOOFFONE
/**********************************************************************************Function name     :   EcuM_OnGoOffOneDescription       :   This call allows the system designer to notify that the GO OFF Istate is about to be entered.Parameter (in)    :   NoneParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/
FUNC(void , ECUM_CALLOUT_CODE) EcuM_OnGoOffOne(void )
{/*Update Flag variable to indicate that the execution reached the particular APi call.* Variable provided only for Debug purpose*/EcuM_IsOnGoOffOneReached_b = TRUE;}
#endif#ifndef ECUM_CFG_ON_GOOFFTWO
/**********************************************************************************Function name     :   EcuM_OnGoOffTwoDescription       :   This call allows the system designer to notify that the GO OFF IIstate is about to be entered.Parameter (in)    :   NoneParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/
FUNC(void , ECUM_CALLOUT_CODE) EcuM_OnGoOffTwo(void )
{/*Update Flag variable to indicate that the execution reached the particular APi call.* Variable provided only for Debug purpose*/EcuM_IsOnGoOffTwoReached_b = TRUE;
#if (ECUM_STARTUP_DURATION == TRUE) /*will activate the Run time measurement*/EcuM_Shutdown_end_ticks_u64 = EcuM_GetTicks();EcuM_Shutdown_delta_us_u32 = EcuM_GetDuration(EcuM_Shutdown_end_ticks_u64,EcuM_Shutdown_begin_ticks_u64);#if (ECUM_CFG_NVM_BLOCK_CONFIGURED == TRUE)/*update the RAM variable in NV memory to the current shutdown target*/EcuM_Rb_dataShutdownInfo_st.ShutdownInfo.TimeMeasured = EcuM_Shutdown_delta_us_u32;(void)NvM_SetRamBlockStatus(NvMConf_NvMBlockDescriptor_ECUM_CFG_NVM_BLOCK,TRUE);
#endif//ECUM_CFG_NVM_BLOCK_CONFIGURED#endif//ECUM_STARTUP_DURATION/*NOTE to integrator: place the shutdown callouts below*/}
#endif#ifndef ECUM_CFG_AL_SWITCHOFF
/**********************************************************************************Function name     :   EcuM_AL_SwitchOffDescription       :   This callout shall take the code for shutting off the powersupply of the ECU. If the ECU cannot unpower itself, a resetmay be an adequate reaction.Parameter (in)    :   NoneParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/
FUNC(void , ECUM_CALLOUT_CODE) EcuM_AL_SwitchOff(void )
{/*Update Flag variable to indicate that the execution reached the particular APi call.* Variable provided only for Debug purpose*/EcuM_IsALSwitchOffReached_b = TRUE;}
#endif/**********************************************************************************Function name     :   EcuM_AL_ResetDescription       :   This callout shall take the code for resetting the ECU.Parameter (in)    :   reset - Type of reset to be performed.Parameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/FUNC( void, ECUM_CALLOUT_CODE ) EcuM_AL_Reset( VAR(EcuM_ResetType, AUTOMATIC) reset )
{}/**********************************************************************************Function name     :   EcuM_CheckWakeupDescription       :   this will be called from the corresponding driver when a wakeup is detected .Parameter (in)    :   wakeupSource.Parameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/FUNC( void, ECUM_CALLOUT_CODE ) EcuM_CheckWakeup( VAR(EcuM_WakeupSourceType, AUTOMATIC) wakeupSource ){}/**********************************************************************************Function name     :   EcuM_StartWakeupSourcesDescription       :   This callout shall start the given wakeup source(s) so that they are ready to perform wakeup validation.Parameter (in)    :   wakeupSource.Parameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/FUNC( void, ECUM_CALLOUT_CODE ) EcuM_StartWakeupSources( VAR(EcuM_WakeupSourceType, AUTOMATIC) wakeupSource ){}/**********************************************************************************Function name     :   EcuM_StopWakeupSourcesDescription       :   This callout shall stop the given wakeup source(s) after unsucessful wakeup validation..Parameter (in)    :   wakeupSource.Parameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/FUNC( void, ECUM_CALLOUT_CODE ) EcuM_StopWakeupSources( VAR(EcuM_WakeupSourceType, AUTOMATIC) wakeupSource ){}/**********************************************************************************Function name     :   EcuM_CheckValidationDescription       :   This callout is called by EcuM to validate Wakeup source. if a valid wakeup is detected it shall send report to EcuM via EcuM_ValidateWakeupEvent.Parameter (in)    :   wakeupSource.Parameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/FUNC( void, ECUM_CALLOUT_CODE ) EcuM_CheckValidation( VAR(EcuM_WakeupSourceType, AUTOMATIC) wakeupSource ){}/**********************************************************************************Function name     :   EcuM_SwitchOsAppModeDescription       :   This will be called from Master and Slave core Init api's. This is required for CalWup functionality.In Master core this will be started after starting all coresIn Master and Slave core this will be called just before OS Start.Parameter (in)    :   NoneParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/FUNC(void, ECUM_CALLOUT_CODE) EcuM_SwitchOsAppMode(void){}#if ECUM_SLEEP_SUPPORT_ENABLE
/**********************************************************************************Function name     :   EcuM_EnableWakeupSourcesDescription       :   The ECU Manager Module calls EcuM_EnableWakeupSource to allow the system designer to notifywakeup sources defined in the wakeupSource bitfield that SLEEP will be enteredand to adjust their source accordingly.Parameter (in)    :   wakeupSourceParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/FUNC(void, ECUM_CALLOUT_CODE) EcuM_EnableWakeupSources(VAR(EcuM_WakeupSourceType, AUTOMATIC) wakeupSource){}/**********************************************************************************Function name     :   EcuM_DisableWakeupSourcesDescription       :   The ECU Manager Module calls EcuM_DisableWakeupSources to set the wakeup source(s) definedin the wakeupSource bitfield so that they are not able to wake the ECU up.Parameter (in)    :   wakeupSourceParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   NoneRemarks           :
***********************************************************************************/FUNC(void, ECUM_CALLOUT_CODE) EcuM_DisableWakeupSources(VAR(EcuM_WakeupSourceType, AUTOMATIC) wakeupSource){}/**********************************************************************************Function name     :   EcuM_CheckRamHashDescription       :   This callout is intended to provide a RAM integrity test. The goal of this test is to ensurethat after a long SLEEP duration, RAM contents is still consistent.Parameter (in)    :   noneParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   uint8Remarks           :
***********************************************************************************/FUNC(uint8, ECUM_CALLOUT_CODE) EcuM_CheckRamHash(void){}/**********************************************************************************Function name     :   EcuM_GenerateRamHashDescription       :Parameter (in)    :   noneParameter (inout) :   NoneParameter (out)   :   NoneReturn value      :   noneRemarks           :
***********************************************************************************/FUNC(void, ECUM_CALLOUT_CODE) EcuM_GenerateRamHash(void){}
#endif//ECUM_SLEEP_SUPPORT_ENABLE
#define ECUM_STOP_SEC_CALLOUT_CODE
#include "EcuM_Cfg_MemMap.h"

静态代码 

我们首先来看一些常用的函数解析,休眠涉及的API在这里就不在赘述了,有兴趣的读者可以参考《AUTOSAR_SWS_ECUStateManager.pdf》与《RTA-BSWReferenceGuide.pdf》中寻找详细的解析。

  • EcuM_MainFunction:函数周期调用,目的是在操作系统启动和运行时实现EcuM的所有活动。
  • EcuM_Init:初始化ECU状态管理器并执行启动过程。函数将永远不会返回(它调用Startos)。
  • EcuM_Shutdown:这个函数通常从OS关闭的回调函数处调用,它接管执行控制并执行EcuM_OnGoOffTwo以及EcuM_AL_SwitchOff活动。
  • EcuM_GoDown:指示ECU状态管理器模块进入关闭阶段。
  • EcuM_SelectShutdownTarget:选择ShutdownTarget。
  • EcuM_ErrorHook:如果出现其他错误条件,如包含检查失败或Ram检查失败,EcuM将启动此调用。在这种情况下,不可能继续处理,Ecu必须停止。
  • EcuM_DeterminePbConfiguration:返回一个指向完全初始化的EcuM_ConfigType结构的指针,该结构包含ECU Manager模块和所有其他BSW模块的Post Build配置数据。
  • EcuM_OnGoOffTwo:执行GO OFF II 动作。

下图为ETAS针对EcuM相关代码流程:


十六宿舍 原创作品,转载必须标注原文链接。

©2023 Yang Li. All rights reserved.

欢迎关注 『十六宿舍』,大家喜欢的话,给个👍,更多关于嵌入式相关技术的内容持续更新中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/336987.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java集合【超详细】

文章目录 一、集合框架1.1 概述1.2 数组和集合的区别1.3 Java集合框架体系1.4 数据结构1.4.1 栈、队列、数组、队列1.4.2 二叉树【理解】1.4.3 二叉查找树【理解】1.4.4 平衡二叉树【理解】1.4.5 红黑树【理解】 1.5 泛型 二、Collection集合2.1 Collection 集合概述和使用【应…

如何利用智能算法降低成本,扩大收益?

算法交易(Algorithm Trading)是一种投资策略,它使用计算机算法来分析市场数据,制定交易决策,并自动执行交易。算法交易的主要目标是利用市场价格波动来获取利润,同时降低人为干预的风险和成本。 量化交易中…

【漏洞复现】WordPress Country State City Dropdown CF7插件 SQL注入漏洞(CVE-2024-3495)

0x01 产品简介 Country State City Dropdown CF7插件是一个功能强大、易于使用的 WordPress 插件,它为用户在联系表单中提供国家.州/省和城市的三级下拉菜单功能,帮助用户更准确地填写地区信息。同时,插件的团队和支持也非常出色&#xff0c…

MySQL 索引的使用

本篇主要介绍MySQL中索引使用的相关内容。 目录 一、最左前缀法则 二、索引失效的场景 索引列运算 字符串无引号 模糊查询 or连接条件 数据分布 一、最左前缀法则 当我们在使用多个字段构成的索引时(联合索引),需要考虑最左前缀法则…

COMSOL中液晶材料光学特性模拟

前面我们根据FDTD官方文档设置了液晶指向的模型。COMSOL也可以根据相似的方法设置各项异性的周期性变化的材料。 该方法参考了luneburg_lens的COMSOL文档 在给出的文件中,可以发现定义-变量中可以使用默认坐标作为变量,即xyz。因此,折射率也可…

德人合科技——天锐绿盾内网安全管理软件 | -文档透明加密模块

天锐绿盾文档加密功能能够为各种模式的电子文档提供高强度加密保护,丰富的权限控制以及灵活的应用管理,帮助企业构建更严密的立体保密体系。 PC地址: https://isite.baidu.com/site/wjz012xr/2eae091d-1b97-4276-90bc-6757c5dfedee ————…

【算法】MT2 棋子翻转

✨题目链接: MT2 棋子翻转 ✨题目描述 在 4x4 的棋盘上摆满了黑白棋子,黑白两色棋子的位置和数目随机,其中0代表白色,1代表黑色;左上角坐标为 (1,1) ,右下角坐标为 (4,4) 。 现在依次有一些翻转操作&#…

【并发程序设计】12.内存映射

12.内存映射 使一个磁盘文件与内存中的一个缓冲区相映射&#xff0c;进程可以像访问普通内存一样对文件进行访问&#xff0c;不必再调用read,write&#xff0c;更加高效。 用到的函数 mmap函数 原型&#xff1a; #include <sys/mman.h> void* mmap(void* start, size_…

py黑帽子学习笔记_web攻击

python网络库 py2的urllib2 py3好像把urllib2继承到了标准库urllib&#xff0c;直接用urllib就行&#xff0c;urllib2在urllib里都有对应的接口 py3的urllib get请求 post请求&#xff0c;和get不同的是&#xff0c;先把post请求数据和请求封装到request对象&#xff0c;再…

亚马逊云科技专家分享 | OPENAIGC开发者大赛能量加油站6月5日场预约开启~

由联想拯救者、AIGC开放社区、英特尔联合主办的“AI生成未来第二届拯救者杯OPENAIGC开发者大赛”自上线以来&#xff0c;吸引了广大开发者的热情参与。 为了向技术开发者、业务人员、高校学生、以及个体创业人员等参赛者们提供更充分的帮助与支持&#xff0c;AIGC开放社区特别…

lua 计算第几周

需求 计算当前赛季的开始和结束日期&#xff0c;2024年1月1日周一是第1周的开始&#xff0c;每两周是一个赛季。 lua代码 没有处理时区问题 local const 24 * 60 * 60 --一整天的时间戳 local server_time 1716595200--todo:修改服务器时间 local date os.date("*t…

解析前端开发中同源策略与配置代理

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 在前端开发中&#xff0c;跨域请求是一个常见的问题。同源策略限制了浏览器中一个页面…

2024中青杯数学建模竞赛A题人工智能视域下养老辅助系统的构建思路代码论文分析

2024中青杯数学建模A题论文和代码已完成&#xff0c;代码为A题全部问题的代码&#xff0c;论文包括摘要、问题重述、问题分析、模型假设、符号说明、模型的建立和求解&#xff08;问题1模型的建立和求解、问题2模型的建立和求解、问题3模型的建立和求解&#xff09;、模型的评价…

使用 Django Model 构建强大的数据库模型

文章目录 创建一个简单的 Django Model迁移数据库使用 Django Shell 操作模型Django Admin结论 在 Django 中&#xff0c;Model 是构建数据库模型的基础。它允许开发人员定义数据的结构&#xff0c;并提供了方便的方式来与数据库进行交互。本文将介绍如何使用 Django Model 来创…

光环云携手火山引擎共推全栈AI服务,赋能千行百业智能化转型,助力新质生产力发展

5月15日&#xff0c;2024春季火山引擎FORCE原动力大会在北京举办。作为智算云网综合服务提供商&#xff0c;光环云受邀出席大会&#xff0c;与火山引擎共同探索大模型时代下行业发展的新趋势。 会上&#xff0c;光环云数据有限公司正式与火山引擎签署生态伙伴合作协议&#xf…

Goby 漏洞发布|万户ezEIP企业管理系统 /member/success.aspx 命令执行漏洞

漏洞名称&#xff1a;万户ezEIP企业管理系统 /member/success.aspx 命令执行漏洞 English Name&#xff1a;Wanhu-ez-EIP /member/success.aspx Command Execution Vulnerability CVSS core: 9.0 影响资产数&#xff1a;6175 漏洞描述&#xff1a; 万户ezEIP是一种企业资源…

服务器内存与CPU要占用多少才合理?

一 通常服务器内存占用多少合理&#xff1f;cpu占用多少才合理&#xff1f; 1 通常配置范围建议&#xff1a; 建议CPU使用率不高于80%&#xff1b;内存使用率不高于80%&#xff1b; 注意&#xff1a;具体情况还需要根据服务器的实际负载和应用场景来判断。 2 内存使用率&…

【Linux系列】深入解析 `kill` 命令:Linux 下的进程管理利器

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Java的JDBC编程

博主主页: 码农派大星. 数据结构专栏:Java数据结构 数据库专栏:MySQL数据库 关注博主带你了解更多数据结构知识 1. Java的数据库编程&#xff1a;JDBC 数据库驱动包&#xff1a;不同的数据库&#xff0c;对应不同的编程语言提供了不同的数据库驱动包&#xff0c;如&#xff1…

JDK JRE JVM 三者的关系

总结&#xff1a; 1. jdk 中 的 javac 编译器将 .java 文件编译为 .class 字节码文件 &#xff08;编译&#xff09; 2. jre 执行 .class 字节码文件 &#xff08;运行&#xff09; 3. jre 通过 jvm 运行程序&#xff0c;确保程序能够在不同平台上正确执行&#xff08;实现跨平…