基于S32K144驱动NSD8308

文章目录

    • 1.前言
    • 2.芯片介绍
      • 2.1 芯片简介
      • 2.2 硬件特性
      • 2.3 软件资源
      • 2.4 芯片资料
    • 3.测试环境
    • 4.软件驱动
      • 4.1 SPI
      • 4.2 寄存器
      • 4.3 SPI ON/OFF控制
      • 4.4 PWM控制
    • 5.测试情况

1.前言

最近有些客户在前期调试NSD8308时,软件上遇到一些问题,正好笔者手上有一套NSD8308评估板,抽空写了一个简单的软件驱动,方便客户前期调试评估。

2.芯片介绍

2.1 芯片简介

NSD8308是纳芯微主推的八路半桥驱动,目标应用有汽车空调风门电机、后视镜调节/折叠电机、通用继电器或LED小灯。

该芯片支持同时、顺序或并行模式驱动直流电机,并支持电机的正转、反转、慢速衰减和快速衰减操作。

NSD8308内部有8个可配置的PWM发生器,可以用于启动或堵转条件下限制电机电流或者对LED灯进行调光。

此外,该设备还具备SPI接口,用于控制所有输出并提供诊断信息,包括正常操作、上电复位(POR)、VM欠压/过压、过流、过温保护和开路负载状态。

2.2 硬件特性

NSD8308的关键硬件特性包括:

  • 8路半桥驱动:每个半桥通道可提供1A电流,所有通道全开时最大3A。
  • 宽电压范围:工作电压范围4.5V至36V,可配置。
  • 超低静态睡眠模式电流。
  • 内置8个PWM发生器,每个PWM发生器提供4种PWM频率选项(80/100/200/2000Hz)和8位分辨率的占空比(1/255,约0.4%)。
  • 集成诊断和故障保护功能:包括欠压和过压保护、过流/短路保护、过温警告和关断、开路负载诊断、专用的nFault指示引脚。
  • 半桥输出斜率控制:提供两种选择,0.6V/µs(默认)或2.5V/µs。
  • 支持off-state诊断,涵盖H桥/半桥,高边驱动,低边驱动几种场景。
  • HTSSOP24封装,尺寸为7.8mm × 4.4mm,底部带有散热焊盘。
  • 符合AEC-Q100 Grade1标准。
  • 符合RoHS和REACH合规性。

2.3 软件资源

软件方面,NSD8308通过以下方式进行控制和配置:

  • SPI接口:NSD8308和MCU通信通过SPI接口,且NSD8308做从机。
  • 寄存器配置:包括状态寄存器、控制寄存器、PWM映射控制寄存器、PWM频率控制寄存器、PWM占空比控制寄存器等,用于详细配置设备的行为。
  • 故障清除:通过SPI命令可以清除故障状态,恢复正常操作。
  • 诊断功能:包括过流保护、开路负载诊断、过温保护等,并通过SPI提供相应的状态信息。
  • 电源管理:包括上电复位(POR)和睡眠模式,以实现低功耗运行。

2.4 芯片资料

数据手册下载地址:

  • NSD8308-Q1_Datasheet_version_Rev1.5

3.测试环境

纳芯微官方有一个NSD8308开发板以及配套的MCU底板(S32K144),可以配合他们提供的上位机对NSD8308进行控制。这次测试基于MCU底板进行编程两块板子的连接示意图如下:

NSD8308EVK+MCU底板

该MCU底板的对外接口和NXP官方的S32K144EVB兼容,以S32K144EVB为参照对应的引脚连接图如下所示:

S32K144连接NSD8308

以NSD8308引脚分布图为参照对应的连接图如下所示,其中OUT1和OUT2,以及OUT3和OUT4分别接一个电机作为负载,电机空载电流在20mA左右:

NSD8308连接S32K144和电机

4.软件驱动

接下来基于S32K144+S32DS 2.2介绍如何驱动NSD8308。

4.1 SPI

NSD8308的SPI接口要求如下图:

NSD8308 SPI接口要求

  • 一帧16bit,MSB
  • NSD8308做从机
  • CPOL为0,即时钟高电平有效
  • CPHA为1,即在第二个边沿采样
  • 支持的最大频率为5MHz

NSD8308通过SPI接收的一帧数据为16bit,组成部分如下:

  • MCU发给NSD8308的帧结构

NSD8308接收的帧结构

如果是给NSD8308发送读指令,DATA建议填入0x00。

  • NSD8308回给MCU的帧结构

NSD8308发送的帧结构

如果NSD8308收到的是写指令,那返回的DATA是被重新写入值的寄存器原先存储的数据。

S32K144的SPI外设配置如下:

  1. 引脚配置如下图:

SPI引脚

  1. SPI参数配置如下图:

SPI参数

  1. 发送和接收的帧结构的代码如下图:

帧结构

  1. 读写寄存器的API函数如下图所示:

读写寄存器函数

4.2 寄存器

NSD8308内部的寄存器主要有如下几种:

状态寄存器(Status Registers):

  • STA_0: 包含过温关闭(OTSD)、过温警告(OTWARN)、开路负载(OPL)、过流(OC)、电源监控下欠压(VM_UV)、电源监控上过压(VM_OV)和上电复位(NPOR)状态。
  • OC_STA_1/2: 包含各半桥通道的过流状态。
  • OPL_STA_1/2: 包含各半桥通道的开路负载状态。
  • HB_STA_1/2: 包含各半桥通道的输出电压状态。

控制寄存器(Control Registers):

  • GEN_CTRL_0: 包含关闭诊断比较器使能(OFF_DIAG_COMP_EN)、设备ID(DEVICE_ID)、过流屏蔽标志(OC_MASK_FLT)、过温警告屏蔽标志(OTW_NMASK_FLT)、过压阈值选择(OVP_H)和诊断清除(DIAG_CLR)。
  • HB_CTRL_1/2/3: 包含各半桥通道的高侧(HS)和低侧(LS)使能控制。
  • HB_PWM_CTRL1/2: 包含各半桥通道的PWM使能和PWM通道禁用控制。
  • FW_CTRL_1/2: 包含各半桥通道的主动和被动续流功能(free-wheeling)。

如果使用PWM控制,发现PWM的低电平没法到0V,可以将对应输出通道的free-wheeling功能打开。

PWM控制寄存器(PWM Control Registers):

  • PWM_MAP_CTRL_1/2/3/4/5/6: 设置每个半桥通道使用的PWM发生器通道。
  • PWM_FREQ_CTRL1/2: 设置PWM发生器的频率。
  • PWM_DC_CTRL1/2/3/4/5/6/7/8: 设置PWM发生器的占空比。

其他控制寄存器(Other Control Registers):

  • HB_SR_CTRL_1/2: 设置半桥通道的输出上升/下降斜率。
  • OPL_CTRL_1/4/9,OPL_OC_CTRL_2/3: 控制开路负载诊断功能,包括屏蔽标志、半桥动作、过流去抖滤波器时间、开路负载阈值和过流保护阈值等。

OPL_CTRL_9寄存器的bit7-bit4需要先通过GEN_CTRL_1寄存器的bit3进行解锁才能写值。

  • OPL_CTRL_5/6/7/8,设置off-state诊断需要的上下拉电流源

特殊功能寄存器(Special Function Registers):

  • GEN_CTRL_1: 包含SS_MOD(扩展频谱配置)、SS_DEV(调制偏差)、RD_CLR_EN(SPI读清除使能)、unlock(寄存器锁定/解锁功能)和SPI_ERR(SPI通信错误标志)。

如果遇到RE、CE实验在53MHz、88MHz等频点超标,可以将GEN_CTRL_1寄存器赋值A0,对应的配置为展频为31.25KHz,deviation为10%,能够解决RE、CE超标的问题。

根据寄存器编写对应的头文件部分代码如下图:

NSD8308寄存器定义文件

4.3 SPI ON/OFF控制

如果使用NSD8308的SPI ON/OFF控制方式,数据手册推荐的操作方式如下:

SPI ON/OFF控制步骤

为了避免红框中的情况,需要确保组成全桥控制的两个半桥通道的使能bit在同一个寄存器中,如OUT1、OUT2、OUT3、OUT4配对使用,OUT5、OUT6、OUT7、OUT8配对使用。且两个配对通道的HS/LS一起打开。

举个例子,使用OUT1和OUT2控制一个有刷电机,如果需要电机正转,需要同时打开OUT1的HS和OUT2的LS,即对寄存器HB_CTRL_1写值0x06。

HB_CTRL_1寄存器

纳芯微原厂推荐的NSD8308初始化加SPI ON/OFF的流程图如下:

NSD8308SPI ON/OFF控制流程图(来源:纳芯微)

对应的NSD8308初始化代码如下图,off-state诊断功能暂未实现。

NSD8308初始化函数

SPI ON/OFF控制代码如下图:

NSD8308 SPI ON/OFF控制函数

4.4 PWM控制

如果使用NSD8308的PWM控制,数据手册推荐的操作方式如下:

PWM控制步骤

纳芯微原厂推荐的NSD8308初始化加PWM控制的流程图如下:

NSD8308PWM控制流程图(来源:纳芯微)

PWM控制涉及到的NSD8308初始化和SPI ON/OFF控制一样,代码就不放了;
PWM控制代码如下图:

NSD8308PWM初始化函数

NSD8308PWM占空比更新函数

5.测试情况

最终完整的工程功能为:

  • OUT1和OUT2控制电机1,每按一次按键,电机1的状态进行切换,正转->停止->反转->停止->正转…
  • OUT3和OUT4控制电机2,OUT3为HS,OUT4为LS,OUT3使用PWM模式,占空比初始值为50%,每按一次按键,占空比减少6%。

工程已放到百度网盘,链接如下:

  • 链接: https://pan.baidu.com/s/1b_3dOqe55Rwr7BAPMsKDLg
  • 提取码: 49sb

实际的效果如下:

NSD8308

OUT3和OUT4的初始波形如下图所示:

  • 软件设置频率200Hz,占空比50%。
    200HZ-50%-PWM输出

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

01- ES6语法

1.ES6相关概念 1.1 什么是ES6 1.1.1 简介 ES6, 全称 ECMAScript 6.0 ,是 JavaScript 的下一个版本标准,2015.06 发版。 ES6 主要是为了解决 ES5 的先天不足,比如 JavaScript 里并没有类的概念,但是目前浏览器的 Ja…

6月17(信息差)

1.马斯克最新预测:未来不再需要手机 将被脑机芯片替代 当地时间6月17日,马斯克高仿号“Not Elon Musk”发帖称:“你会在你的大脑上安装一个Neuralink接口,让你通过思考来控制你的新X手机吗?”对此,马斯克本…

ThinkPHP6图书借阅管理系统

有需要请加文章底部Q哦 可远程调试 ThinkPHP6图书借阅管理系统 一 介绍 此图书借阅管理系统基于ThinkPHP6框架开发,数据库mysql,前端bootstrap。系统角色分为用户和管理员。 技术栈 ThinkPHP6mysqlbootstrapphpstudyvscode 二 功能 用户 1 登录/注销…

骁龙662_高通SM6115主要参数_高通模块方案定制

骁龙662(SM6115)采用了全新的44 Kryo 260 CPU架构,由四核Cortex-A73(高达2.0 GHz)和四核Cortex-A53(高达1.8 GHz)组成。这种架构的设计使得骁龙662在性能上相较于上一代产品有了显著的提升,为用户提供了更快的运行速度和更流畅的使…

BarTender软件最新版下载-bartender条码标签打印软件下载

​​BarTender​​是一款遵循“look and feel”标准的​​条码打印​​软件。​​BarTender​​条码打印软件能够帮助用户挥洒自如,轻松制作出标签条码,包括文本、图形、​​条形码​​和大多数序列化功能。BarTender条码打印软件功能强大、操作简单&…

开源的数字孪生平台

欧洲对工业4.0的追求体现在三个方面: 数字孪生、智能制造和万物互联。 资助2440万欧元的开源数字孪生平台 源代码: http://www.gitpp.com/ccdan/dpqq-digital-twins 这套数字孪生是工业4.0整体规划中的中的一项技术,实现了一种称为“数字…

JSP之原理剖析

什么是JSP: java Server Pages: java服务端页面,也和Servlet一样,用于动态Web技术? 最大特点: 写jsp就像在写HTML区别: HTML只给用户提供静态的数据JSP页面中可以嵌入Java代码,为用户提供动态数据 JSP原…

npm发布自己的插件包:新手教程

npm(Node Package Manager)是Node.js的包管理工具,广泛用于JavaScript项目中。本文将为你介绍如何从零开始发布一个npm插件包。 前提条件 在开始之前,你需要确保以下几点: 安装Node.js和npm:你可以在No…

科凡定制首倡轻高定突围的蓝海战术是明星代言?

4月19日,科凡家居再度重磅发声,正式宣布国际女星舒淇为全球代言人。 纵观定制家居几大一线品牌,欧派代言人胡歌,索菲亚代言人倪妮。尚品宅配代言人赵丽颖,维意定制代言人黄轩,志邦家居代言人周杰伦......大…

【SkiaSharp绘图05】SKPaint详解(三)之ImageFilter(颜色、组合、膨胀、移位、光照、反射、阴影、腐蚀、变换)

文章目录 ImageFilterCreateColorFilter 颜色滤镜CreateCompose 滤镜组合CreateDilate 膨胀滤镜CreateDisplacementMapEffect 移位映射CreateDistantLitDiffuse 光照CreateDistantLitSpecular 反射光照CreateDropShadow阴影效果CreateDropShadowOnly 只阴影效果CreateErode腐蚀…

卡本医疗VENUS登陆香港国际医疗展,探索全球医疗发展新机遇

由香港贸易发展局主办的第15届香港国际医疗及保健展、以及联合香港特别行政区政府举办的第四届亚洲医疗健康高峰论坛在中国香港圆满落幕。 香港国际医疗及保健展是亚太地区最具影响力的B2B医疗贸易展览会之一,辐射海内外市场,本次邀请了超过8500家买家以…

读书笔记-《人人都是产品经理》

在开发工程师与产品经理的段子中,常看到“人人都是产品经理”这句话,用来调侃这个岗位似乎没有什么门槛。 很明显,这句话的出处,即本书作者想表达的是每个人都可以运用产品思维去解决问题。 01 产品 产品:用来解决某…

android常用知识

透明activity样式: android:theme"android:style/Theme.Translucent.NoTitleBar.Fullscreen"这句代码,当你是建的empty activity project时,默认继承的是AppCompat这个类。所以在AndroidMifext.xml文件中用上述代码会导致程序错误&…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 智能成绩表(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 &#x1f…

面试题之CSS

1. 引入样式的方式 外部样式 link import 区别 内部样式 /* 写在头部标签 */ <style></style>行内样式 2. 三行代码画三角形 .triangle{width:0px;border:100px solid;border-color:transparent transparent transparent red; }3.属性的继承 可继承的属性 …

02-ES6新语法

1. ES6 Proxy与Reflect 1.1 概述 Proxy 与 Reflect 是 ES6 为了操作对象引入的 API 。 Proxy 可以对目标对象的读取、函数调用等操作进行拦截&#xff0c;然后进行操作处理。它不直接操作对象&#xff0c;而是像代理模式&#xff0c;通过对象的代理对象进行操作&#xff0c;…

构建基于 LlamaIndex 的RAG AI Agent

I built a custom AI agent that thinks and then acts. I didnt invent it though, these agents are known as ReAct Agents and Ill show you how to build one yourself using LlamaIndex in this tutorial. 我构建了一个自定义的AI智能体&#xff0c;它能够思考然后行动。…

【ROS1转ROS2示例】

ROS1中的代码&#xff1a; 这是一个循环函数&#xff1a; ros::Rate loop_rate(10); // Adjust the publishing rate as neededwhile (ros::ok()){loop_rate.sleep();} 如果转ROS2&#xff0c;可以使用rclcpp::WallRate或者直接依赖于执行器(Executor)的循环来实现类似的功…

[渗透测试学习] BoardLight-HackTheBox

BoardLight-HackTheBox 信息搜集 nmap扫描一下 nmap -sV -v 10.10.11.11扫描结果如下 PORT STATE SERVICE VERSION 22/tcp open ssh OpenSSH 8.2p1 Ubuntu 4ubuntu0.11 (Ubuntu Linux; protocol 2.0) 80/tcp open http Apache httpd 2.4.41 ((Ubuntu))80端口有h…

基于STM32和人工智能的智能四轴飞行器系统

目录 引言环境准备智能四轴飞行器系统基础代码实现&#xff1a;实现智能四轴飞行器系统 4.1 数据采集模块4.2 数据处理与分析4.3 控制系统4.4 用户界面与数据可视化应用场景&#xff1a;智能飞行器管理与优化问题解决方案与优化收尾与总结 1. 引言 随着无人机技术的发展&…