目录:
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.测试情况
最近有些客户在前期调试NSD8308时,软件上遇到一些问题,正好笔者手上有一套NSD8308评估板,抽空写了一个简单的软件驱动,方便客户前期调试评估。
NSD8308是纳芯微主推的八路半桥驱动,目标应用有汽车空调风门电机、后视镜调节/折叠电机、通用继电器或LED小灯。
该芯片支持同时、顺序或并行模式驱动直流电机,并支持电机的正转、反转、慢速衰减和快速衰减操作。
NSD8308内部有8个可配置的PWM发生器,可以用于启动或堵转条件下限制电机电流或者对LED灯进行调光。
此外,该设备还具备SPI接口,用于控制所有输出并提供诊断信息,包括正常操作、上电复位(POR)、VM欠压/过压、过流、过温保护和开路负载状态。
NSD8308的关键硬件特性包括:
软件方面,NSD8308通过以下方式进行控制和配置:
数据手册下载地址:
纳芯微官方有一个NSD8308开发板以及配套的MCU底板(S32K144),可以配合他们提供的上位机对NSD8308进行控制。这次测试基于MCU底板进行编程两块板子的连接示意图如下:
该MCU底板的对外接口和NXP官方的S32K144EVB兼容,以S32K144EVB为参照对应的引脚连接图如下所示:
以NSD8308引脚分布图为参照对应的连接图如下所示,其中OUT1和OUT2,以及OUT3和OUT4分别接一个电机作为负载,电机空载电流在20mA左右:
接下来基于S32K144+S32DS 2.2介绍如何驱动NSD8308。
NSD8308的SPI接口要求如下图:
NSD8308通过SPI接收的一帧数据为16bit,组成部分如下:
如果是给NSD8308发送读指令,DATA建议填入0x00。
如果NSD8308收到的是写指令,那返回的DATA是被重新写入值的寄存器原先存储的数据。
S32K144的SPI外设配置如下:
NSD8308内部的寄存器主要有如下几种:
状态寄存器(Status Registers):
控制寄存器(Control Registers):
如果使用PWM控制,发现PWM的低电平没法到0V,可以将对应输出通道的free-wheeling功能打开。
PWM控制寄存器(PWM Control Registers):
其他控制寄存器(Other Control Registers):
OPL_CTRL_9寄存器的bit7-bit4需要先通过GEN_CTRL_1寄存器的bit3进行解锁才能写值。
特殊功能寄存器(Special Function Registers):
如果遇到RE、CE实验在53MHz、88MHz等频点超标,可以将GEN_CTRL_1寄存器赋值A0,对应的配置为展频为31.25KHz,deviation为10%,能够解决RE、CE超标的问题。
根据寄存器编写对应的头文件部分代码如下图:
如果使用NSD8308的SPI ON/OFF控制方式,数据手册推荐的操作方式如下:
为了避免红框中的情况,需要确保组成全桥控制的两个半桥通道的使能bit在同一个寄存器中,如OUT1、OUT2、OUT3、OUT4配对使用,OUT5、OUT6、OUT7、OUT8配对使用。且两个配对通道的HS/LS一起打开。
举个例子,使用OUT1和OUT2控制一个有刷电机,如果需要电机正转,需要同时打开OUT1的HS和OUT2的LS,即对寄存器HB_CTRL_1写值0x06。
纳芯微原厂推荐的NSD8308初始化加SPI ON/OFF的流程图如下:
对应的NSD8308初始化代码如下图,off-state诊断功能暂未实现。
SPI ON/OFF控制代码如下图:
如果使用NSD8308的PWM控制,数据手册推荐的操作方式如下:
纳芯微原厂推荐的NSD8308初始化加PWM控制的流程图如下:
PWM控制涉及到的NSD8308初始化和SPI ON/OFF控制一样,代码就不放了;PWM控制代码如下图:
最终完整的工程功能为:
工程已放到百度网盘,链接如下:
实际的效果如下:
OUT3和OUT4的初始波形如下图所示:
NSD8308-Q1_Datasheet_version_Rev1.5: https://www.novosns.com/Public/Uploads/uploadfile/files/20231122/NSD8308-Q1_Datasheet_version_Rev1.5_EN.pdf