AUTOSAR架构下TC3xx平台的MCAL时钟系统配置实践

原创 汽车电子嵌入式 2023-12-18 07:18

前言

我们在《TC3xx芯片Clock System功能详解-时钟源OSC》,《TC3xx芯片Clock System功能详解-锁相环PLL》,《TC3xx芯片Clock System功能详解-时钟分配CCU》三文中详细介绍了TC3xx芯片的Clock Sytstem并以手写代码(配置寄存器)的方式配置了一个完整的时钟系统,而使用AUTOSAR架构的项目的时钟系统是通过工具(Davinci, EB, e.g.)配置生成的,本文就来介绍AUTOSAR架构下TC3xx平台的MCAL时钟系统配置实践。


注意:本文不再介绍TC3xx的时钟系统的概念,如果对TC3xx的时钟不熟悉请先阅读上述三篇前文。



注:本文章引用了一些第三方工具和文档,若有侵权,请联系作者删除!


正文

1. MCU模块介绍

MCU直接访问微控制器硬件,位于微控制器抽象层(MCAL)中。

 


MCU模块为基本的微控制器初始化、上下电、复位和其他MCAL软件模块所需的微控制器特定功能提供服务。MCU模块初始化之前(提供标准接口服务之前)ECU还会有一段启动代码,启动代码是非常特定于单片机的(非AUTOSAR标准定义之内,和每个具体的芯片厂商强绑定)。本文着重接受AUTOSAR标准MCU模块,提到系统启动代码只是为了提示在标准化的MCU初始化能够启动之前必须考虑到的一些功能。

 

每个具体MCU的启动代码部分都是独有的,MCU模块只能描述/提供那些公有的服务,如时钟/RAM初始化,上下电,重启


MCU驱动提供的具体服务:


--描述MCAL其他模块没有覆盖到的功能配置,如时钟设置

--设置锁相环和时钟分配

-- RAM段初始化服务

--激活MCU低功耗模式

--执行MCU重启

--获取MCU重启的原因


其中的难点和重点就是MCU时钟的配置。


2. MCAL上的时钟Clock配置

2.1 AUTOSAR标准关于时钟的描述

2.1.1 McuClockSettingConfig

AUTOSAR标准规定了时钟(Clock)的顶层配置容器名为McuClockSettingConfig。由于每个厂家具体型号(Infineon, Renesas, NXP, ST e.g.)的MCU时钟配置完全不一样,McuClockSettingConfig内部的时钟具体配置无法统一,也就无法通过AUTOSAR标准规定,需要根据具体芯片来配置。也就是说,McuClockSettingConfig配置容器下的Container是非标准的配置

 


McuClockSettingConfig包括McuClockReferencePoint的子配置容器。

 


2.1.2 McuClockReferencePoint

McuClockReferencePoint配置时钟引用项。比如,我们在配置Can Driver模块时需要引用一个Can的模块时钟,这个引用(Reference Point)就是来自McuClockReferencePoint的配置。

 


2.2 TC3xx芯片MCAL时钟的配

MCAL的时钟配置主要就是配置MCU模块的McuClockSettingConfig配置容器。也就是将前面文章中手写的代码通过图形化工具进行配置。

 


McuClockSettingConfig下包括GeneralMcuClockReferencePoint两个配置容器,Genral下包括McuSystemPllSettingConfig, McuPeripheralPllSettingConfig, McuPllDistributionSettingConfig, McuExternalClockOutputConfig, McuClockMonitorConfig几个配置容器。


 

2.2.1 McuSystemPllSettingConfig

McuSystemPllSettingConfig主要配置时钟源和fPLL0. 比如我们要配置选用OSC作为时钟源,且配置fPLL0100MHz.


需求:配置fPLL0100MHz.


公式:fPLL0 = (N* fOSC) / (P * K2)


fOSC == 20MHz


N = SYSPLLCON0.NDIV + 1 = 29(0x1D, 配置SYSPLLCON0.NDIV29) + 1 = 30

P = SYSPLLCON0.PDIV + 1 = 0(配置SYSPLLCON0.PDIV0) + 1 = 1

K2 = SYSPLLCON1.K2DIV + 1 = 5(配置SYSPLLCON1.K2DIV5) +1 = 6

 


如上图种配置N,P,K2参数参考第一章节内容即可,这里面有两个地方需要捎带下:

1)两个xxxChangeDelay配置参数是配置K2参数倍频/分频时钟时渐变升高或者降低的时间,提高系统的稳定性。范围是5-100ms,这里配置15ms是个经验值。


2McuFmPllEnable配置是否使能频率调制(Frequency Modulation),McuFMPllModAmp配置频率调制幅值。至于什么是频率调制,请参考手册,作者也不懂。置为为啥配置为1.25,手册上的推荐值。


 

2.2.2 McuPeripheralPllSettingConfig

McuPeripheralPllSettingConfig主要配置fPLL1fPLL2以及fsource0fsource1的时钟源,以及K3的选择。


需求

配置fPLL1320MHz.

配置fPLL2200MHz.


配置fsource0, fsource1, and fsource2三个时钟的时钟源为:

fsource0 = fPLL0

fsource1 = fPLL1

fsource2 = fPLL2


计算公式:


fPLL1 = (N* fOSC) / (P * K2)


fPLL2 = (N* fOSC) / (P * K3 * 1.6) if DIVBY = 0 or fPLL2 = (N* fOSC) / (P * K3 * 2) if DIVBY = 1


同样,我们配置:

N = 32

P = 1

K2 = 2

K3 = 2

Div = 0


fPLL1 = (N* fOSC) / (P * K2) = (32 * 20) / (1 * 2) = 320 MHz.


fPLL2 = (N* fOSC) / (P * K3 * 1.6) if DIVBY = 0 or fPLL2 = (N* fOSC) / (P * K3 * 2) if DIVBY = 1

= (32 * 20) / (1 * 2 * 1.6) = 200 MHz.


 

2.2.3 McuPllDistributionSettingConfig

McuPllDistributionSettingConfig配置所有外设的时钟,主要配置每个外设模块的时钟源以及分频系数。


需求fMCAN clock配置到80MHz.


第一步:了解时钟源

从第二章已知

fPLL0100MHz.

fPLL1320MHz.

fPLL2200MHz.


第二步CCUCON0.CLKSEL配置为0x01B

也就是

fsource0 == fPLL0 == 100MHz

fsource1 == fPLL1 == 320MHz

fsource2 == fPLL2 == 200MHz


第三步:配置CCUCON1.MCANDIV = 0x4H

也就是

fMCANI = fsource1/4 = 320/4 = 80MHz.


第四步:配置CCUCON1.CLKSELMCAN = 01BfMCANI is used as clock source fMCAN

也就是

fMCANI ==  fMCAN  == 80MHz.


 

2.2.4 McuExternalClockOutpuConfig

McuExternalClockOutpuConfig配置外部时钟输入,一般使用OSC不会使用外部时钟输入,这个配置项也就不用配置。


 

2.2.5 McuClockMonitorConfig

McuClockMonitorConfig配置时钟的监控功能,在我们使用版本的MCAL中这个功能都是Disable的,还未开放。


2.2.6 McuClockReferencePoint

配置时钟的引用项,这里配置一个Can Driver模块需要使用到时钟引用项。

 


Can Driver模块需要引用这个时钟引用项。

 

 

2.3 小结

只要我们把第13章中的内容都理解了,配置MCAL中的时钟就比较简单了。AUTOSARMCAL模块隔离硬件,对上层提供统一的接口,具体的配置因芯片不同而不同。



End

「汽车电子嵌入式在CSDN上同步推出AUTOSAR精进之路专栏,本专栏每个模块完全按实际项目中开发及维护过程来详细介绍。模块核心概念介绍、实际需求描述、实际工程配置、特殊需求介绍及背后原理、实际工程使用经验总结。目的是让读者看完每一个章节后能理解原理后根据需求完成一个模块的配置或者解决一个问题。」


点击文章最后左下角的阅读原文可以获取更多信息


或者复制如下链接到浏览器获取更多信息

https://blog.csdn.net/qq_36056498/article/details/132125693


文末福利




1
.如需汽车电子嵌入式收集的学习文档,
后台回复“

资料

即可免费下载;

2.为便于技术交流,创建了汽车电子嵌入式技术交流群,可尽情探讨AP,CP,DDS,SOME/IP等前沿热点话题,后台回复“加群”即可加入;



注:本文引用了一些第三方工具和文档,若有侵权,请联系作者删除!


推荐阅读

汽车电子嵌入式精彩文章汇总第一期:20210530-20230703

AUTOSAR 架构下EcuM唤醒源事件详解

AUTOSAR架构下NVM Block连续写及Default Value问题分析

AUTOSAR架构下NvM模块详细分析

AUTOSAR架构下报文掉线超时不上报问题分析

Classic Autosar下的以太网通讯架构概览

通信中间件Someip服务化通信

AUTOSAR架构下Fee详细分析

TC37x芯片FLASH基本概念介绍

AUTOSAR架构下Fls详细分析

TC3xx芯片DMU介绍

TC3xx芯片MPU介绍

TC3xx芯片的Trap详解

AUTOSAR架构下的OS错误处理

AUTOSAR架构下QM Application如何访问ASIL Application

AUTOSAR架构下多核启动

TC3xx芯片的Trap详解(二)

AUTOSAR架构下多核Shutdown

AUTOSAR架构下多核通信

RH850U2A芯片平台Spinlock的底层实现

TC3xx芯片Clock System功能详解-时钟源OSC

TC3xx芯片Clock System功能详解-锁相环PLL

TC3xx芯片Clock System功能详解-时钟分配CCU

End



欢迎点赞,关注,转发,在看,您的每一次鼓励,都是我最大的动力!

汽车电子嵌入式

微信扫描二维码,关注我的公众号

评论
  • 在电子工程领域,高速PCB设计是一项极具挑战性和重要性的工作。随着集成电路的迅猛发展,电路系统的复杂度和运行速度不断提升,对PCB设计的要求也越来越高。在这样的背景下,我有幸阅读了田学军老师所著的《高速PCB设计经验规则应用实践》一书,深感受益匪浅。以下是我从本书中学习到的新知识和经验分享,重点涵盖特殊应用电路的PCB设计、高速PCB设计经验等方面。一、高速PCB设计的基础知识回顾与深化 在阅读本书之前,我对高速PCB设计的基础知识已有一定的了解,但通过阅读,我对这些知识的认识得到了进一步的深
    金玉其中 2024-12-05 10:01 45浏览
  • TOF多区传感器: ND06   ND06是一款微型多区高集成度ToF测距传感器,其支持24个区域(6 x 4)同步测距,测距范围远达5m,具有测距范围广、精度高、测距稳定等特点。适用于投影仪的无感自动对焦和梯形校正、AIoT、手势识别、智能面板和智能灯具等多种场景。                 如果用ND06进行手势识别,只需要经过三个步骤: 第一步&
    esad0 2024-12-04 11:20 112浏览
  • 当前,智能汽车产业迎来重大变局,随着人工智能、5G、大数据等新一代信息技术的迅猛发展,智能网联汽车正呈现强劲发展势头。11月26日,在2024紫光展锐全球合作伙伴大会汽车电子生态论坛上,紫光展锐与上汽海外出行联合发布搭载紫光展锐A7870的上汽海外MG量产车型,并发布A7710系列UWB数字钥匙解决方案平台,可应用于数字钥匙、活体检测、脚踢雷达、自动泊车等多种智能汽车场景。 联合发布量产车型,推动汽车智能化出海紫光展锐与上汽海外出行达成战略合作,联合发布搭载紫光展锐A7870的量产车型
    紫光展锐 2024-12-03 11:38 126浏览
  • 作为优秀工程师的你,已身经百战、阅板无数!请先醒醒,新的项目来了,这是一个既要、又要、还要的产品需求,ARM核心板中一个处理器怎么能实现这么丰富的外围接口?踌躇之际,你偶阅此文。于是,“潘多拉”的魔盒打开了!没错,USB资源就是你打开新世界得钥匙,它能做哪些扩展呢?1.1  USB扩网口通用ARM处理器大多带两路网口,如果项目中有多路网路接口的需求,一般会选择在主板外部加交换机/路由器。当然,出于成本考虑,也可以将Switch芯片集成到ARM核心板或底板上,如KSZ9897、
    万象奥科 2024-12-03 10:24 99浏览
  • 概述 说明(三)探讨的是比较器一般带有滞回(Hysteresis)功能,为了解决输入信号转换速率不够的问题。前文还提到,即便使能滞回(Hysteresis)功能,还是无法解决SiPM读出测试系统需要解决的问题。本文在说明(三)的基础上,继续探讨为SiPM读出测试系统寻求合适的模拟脉冲检出方案。前四代SiPM使用的高速比较器指标缺陷 由于前端模拟信号属于典型的指数脉冲,所以下降沿转换速率(Slew Rate)过慢,导致比较器检出出现不必要的问题。尽管比较器可以使能滞回(Hysteresis)模块功
    coyoo 2024-12-03 12:20 171浏览
  • 11-29学习笔记11-29学习笔记习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-02 23:58 96浏览
  • 最近几年,新能源汽车愈发受到消费者的青睐,其销量也是一路走高。据中汽协公布的数据显示,2024年10月,新能源汽车产销分别完成146.3万辆和143万辆,同比分别增长48%和49.6%。而结合各家新能源车企所公布的销量数据来看,比亚迪再度夺得了销冠宝座,其10月新能源汽车销量达到了502657辆,同比增长66.53%。众所周知,比亚迪是新能源汽车领域的重要参与者,其一举一动向来为外界所关注。日前,比亚迪汽车旗下品牌方程豹汽车推出了新车方程豹豹8,该款车型一上市就迅速吸引了消费者的目光,成为SUV
    刘旷 2024-12-02 09:32 143浏览
  • 光伏逆变器是一种高效的能量转换设备,它能够将光伏太阳能板(PV)产生的不稳定的直流电压转换成与市电频率同步的交流电。这种转换后的电能不仅可以回馈至商用输电网络,还能供独立电网系统使用。光伏逆变器在商业光伏储能电站和家庭独立储能系统等应用领域中得到了广泛的应用。光耦合器,以其高速信号传输、出色的共模抑制比以及单向信号传输和光电隔离的特性,在光伏逆变器中扮演着至关重要的角色。它确保了系统的安全隔离、干扰的有效隔离以及通信信号的精准传输。光耦合器的使用不仅提高了系统的稳定性和安全性,而且由于其低功耗的
    晶台光耦 2024-12-02 10:40 144浏览
  •         温度传感器的精度受哪些因素影响,要先看所用的温度传感器输出哪种信号,不同信号输出的温度传感器影响精度的因素也不同。        现在常用的温度传感器输出信号有以下几种:电阻信号、电流信号、电压信号、数字信号等。以输出电阻信号的温度传感器为例,还细分为正温度系数温度传感器和负温度系数温度传感器,常用的铂电阻PT100/1000温度传感器就是正温度系数,就是说随着温度的升高,输出的电阻值会增大。对于输出
    锦正茂科技 2024-12-03 11:50 146浏览
  • 遇到部分串口工具不支持1500000波特率,这时候就需要进行修改,本文以触觉智能RK3562开发板修改系统波特率为115200为例,介绍瑞芯微方案主板Linux修改系统串口波特率教程。温馨提示:瑞芯微方案主板/开发板串口波特率只支持115200或1500000。修改Loader打印波特率查看对应芯片的MINIALL.ini确定要修改的bin文件#查看对应芯片的MINIALL.ini cat rkbin/RKBOOT/RK3562MINIALL.ini修改uart baudrate参数修改以下目
    Industio_触觉智能 2024-12-03 11:28 115浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦