基于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.mzph.cn/diannao/29760.shtml

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

相关文章

Linux---系统的初步学习【 项目三 磁盘管理与文件系统】

项目三 磁盘管理与文件系统 3.1 项目知识准备 3.1.1 硬盘 ​ 如果从存储数据的介质上来区分,硬盘可分为机械硬盘(Hard Disk Dirve,HHD)和固态硬盘(Solid State Disk,SSD),机械硬盘…

[保姆级教程]uniapp实现页面路由配置

文章目录 新建目录新建页面配置页面路由修改tabBar地址其他:在package.json中的pages配置详细 新建目录 先点击src–》新建–》目录 输入名称,并以此类推完成所有新建目录 新建页面 右击目录,点击新建–》vue文件 弹出弹框,…

电路笔记 : 嘉立创EDA 导入、查找、设计管理器(快速寻找网络标签)功能+DRC错误检查和处理

导入功能 查找功能 可查找多种类型,如原件名称、网络标签等 设计管理器 图层查看 DRC错误 规则设置 线距问题 大多数PCB制造商能够可靠地生产5 mil间距的走线和间隙。这是一个常见的标准,适合大多数消费级和工业级电子产品。在5 mil以上的间距&#xff…

嵌入式中间件_3.嵌入式中间件的一般架构

根据嵌入式中间件的不同类型和其应用对象的不同,其架构也有所不同,通常嵌入式中间件没有统一的架构,这里仅仅列举两种中间件架构。 1.消息中间件 1.1消息中间件原理架构 消息中间件是消息传输过程中保存消息的一种容器。它将消息从它的源中…

VirtualStudio配置QT开发环境

环境 VirtualStudio2022Qt5.12.10 安装msvc工具链(这一步不是必须的) 打开virtual studio,打开Virtual Studio Installer界面选择要安装的msvc版本,点击安装 安装VirtualStudio扩展 在线安装 打开virtual Studio,…

玄机平台流量特征分析-常见攻击事

前言 熟悉常见的攻击流量特征,我们就可以通过主机的一个流量情况来判断主机遭受了何种攻击。这里来看看玄机平台的一道题目。 步骤1.1 这里需要我们找出恶意扫描者,也就是黑客的ip。下载好附件之后用wiresharke打开,直接筛选http协议的流量…

手写精简版TinyHttpd项目(一)

前言: 我们在之前的TinyHttpd的精读(可以在首页去查看)中已经是基本的了解了显示一个网页的基本过程,那么我们学习后可以通过手写一个精简版的进行巩固下。 0.新工程的建立 我们也可以顺带复习下如何通过cmake在ubuntu下新建一个工程(记得提前下载cmake…

MyBatis逆向工程和MyBatisX插件的使用

文章目录 1.ORM思维2.逆向工程3.MyBatisX插件的使用 1.ORM思维 ORM(Object-Relational Mapping,对象-关系映射)是一种将数据库和面向对象编程语言中的对象之间进行转换的技术。它将对象和关系数据库的概念进行映射,最后我们就可以…

MySQL数据库与基本操作(增删改查)

一、数据库的基本概念 数据库要学习的四个基本概念,主要是:数据、数据库系统、数据库、数据管理系统。数据(Date)是描述事物的记录,数据库系统(DBS),数据库管理系统(DBMS…

如何优雅地限制textarea的输入字数?

大家好&#xff0c;我是瑶山&#xff0c;今天聊聊textarea textarea 有基础的同学都知道<textarea>是HTML中的一个标签&#xff0c;用于定义多行的文本输入控件。它允许用户在表单中输入多行文本&#xff0c;相较于单行输入框可以输入更多的内容。 但是&#xff0c;如果…

【牛客面试必刷TOP101】Day33.BM70 兑换零钱(一)和BM71 最长上升子序列(一)

文章目录 前言一、BM70 兑换零钱(一)题目描述题目解析二、BM71 最长上升子序列(一)题目描述题目解析总结 前言 一、BM70 兑换零钱(一) 题目描述 描述&#xff1a; 给定数组arr&#xff0c;arr中所有的值都为正整数且不重复。每个值代表一种面值的货币&#xff0c;每种面值的货币…

7.华为交换机端口配置链路聚合Eth-trunk

目的&#xff1a;两台华为交换机端口配置链路聚合 LSW1配置 [Huawei]interface Eth-Trunk 1 [Huawei-Eth-Trunk1]q [Huawei]int g0/0/1 [Huawei-GigabitEthernet0/0/1]eth-trunk 1 [Huawei-GigabitEthernet0/0/1]int g0/0/2 [Huawei-GigabitEthernet0/0/2]eth-trunk 1LSW2配置…

计算机网络:运输层 - 概述

计算机网络&#xff1a;运输层 - 概述 运输层的任务端口号复用与分用UDP协议首部格式 TCP协议面向字节流 运输层的任务 物理层、数据链路层以及网络层&#xff0c;他们共同解决了将主机通过网络互联起来所面临的问题&#xff0c;实现了主机到主机的通信。 网络层的作用范围是…

如何使用GPT?初学者的指南

ChatGPT是一个非常先进的AI工具&#xff0c;它使用GPT-4架构&#xff0c;能够生成自然的语言回应。它的多功能性和理解复杂指令的能力&#xff0c;使得很多人用它来回答各种问题&#xff0c;就像用Google一样输入关键词。不过&#xff0c;ChatGPT还能做更多事情&#xff0c;下面…

ArcGIS arcpy代码工具——关于工具使用的软件环境说明

系列文章目录 ArcGIS arcpy代码工具——批量对MXD文件的页面布局设置修改 ArcGIS arcpy代码工具——数据驱动工具批量导出MXD文档并同步导出图片 ArcGIS arcpy代码工具——将要素属性表字段及要素截图插入word模板 ArcGIS arcpy代码工具——定制属性表字段输出表格 ArcGIS arc…

【Redis】java客户端(SpringData和jedis)

https://www.oz6.cn/articles/58 https://www.bilibili.com/video/BV1cr4y1671t/?p16 redis官网客户端介绍&#xff1a;https://redis.io/docs/latest/develop/connect/clients/ jedis maven引入依赖 <dependencies><!--引入Jedis依赖--><dependency><…

cms XAMPP搭建帝国cms示例(用于代码审计)

网上大部分都是小皮因为是一键很省事&#xff0c;但本人一直用的xampp所以若有人也是用xampp搭建可以看此篇文章 这里示例为 帝国CMS -v7.5 xampp搭建过程中如果本机存在mysql服务则需要先将mysql服务停止在start xampp的mysql服务 任务管理器----->服务----->找到mys…

揭秘网络盗版游戏产业链,守护游戏安全 | 天堂1私服非法牟利,涉嫌洗黑钱!

近年来&#xff0c;网络盗版游戏现象日益猖獗&#xff0c;尤其是天堂1私服。这些盗版游戏不仅非法牟利&#xff0c;还存在偷税漏税、诱导消费等违法行为。本文将揭示这一产业链的真相&#xff0c;提醒广大游戏玩家保持警惕&#xff0c;并向相关部门举报&#xff0c;共同维护互联…

从0开始开发一个简单web界面的学习笔记(HTML类)

文章目录 什么是HTML页面vscode 开放工具搭建第一个HTML页面编写vscode 如何快速生成代码框架html标签——注释、标题、段落、换行标签格式化标签img 标签(src 属性01)img 属性02(alt、title、width/height、border)a标签href属性a标签target属性表格标签01 基本属性表格标签02…

AV1:帧间预测(一)参考帧管理

​AV1中帧类型 在H.26X系列标准中&#xff0c;根据帧允许的预测模式可以将帧分为I帧、P帧和B帧&#xff0c;根据帧在码流中前后的参考关系又可以分为IRAP、RADL等。AV1也类似地将帧分为4种类型&#xff0c;在码流中用frame_type来标识帧类型。 KEY_FRAME&#xff1a;相当于IDR帧…