通过数据手册创造属于自己的代码

2024-06-07 13:48

本文主要是介绍通过数据手册创造属于自己的代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在开发的过程中我们经常会碰到一些新的芯片,首先要做的就是拿到数据手册,弄懂它的功能,然后就是写代码去驱动这个芯片。到了写驱动代码这一环节,按照通常的习惯就是去网上先找一下有没有类似的可以参考的代码,然后从别的平台移植到自己的平台,再调试一段时间,基本上就通了(我是在读的学生,公司的开发流程还不懂)。

如果经常这样做,心里老是有种不舒服的感觉,我仔细想了一下,大概有这么一些东西。首先就是,无论这个芯片最后有没有调通,运行的怎么样,自己心里明白这是别人的代码。其次就是,如果移植的代码跑的很顺利,那么很自然而然的就不再理会其中的细节,数据手册也马上就抛到脑后,这种做法有个很大的弊端就是如果有一天代码出问题了,这时你对这个芯片的熟悉程序是远远不够的,以至于不能快速的找出问题并解决,还有就是从别人的代码中找到蛛丝马迹并顺藤摸瓜解决问题,我感觉是相当头疼的一件事。最后一点也是最重要的一点,俗话说不想当将军的士兵不是好士兵,既然踏进这个行业,就励志做一名牛逼的工程师,所以不能满足于抄抄别人的代码,做一些移植工作,因为你所移植的代码,究其原点,终究是有人通过数据手册一行一行写出来的。还有就是,如果你开发的东西是相当高精尖的领域,总有时候是你在网上找不到可参考的代码。那么问题来了,这个踏足高精尖领域的工程师,不就是我们的理想吗。最后再说一下,移植代码并不可耻,甚至说一些重复代码是在浪费时间和精力,但是我们必须具备的一项素质就是通过阅读数据手册,能非常熟练的写出它的驱动代码。

今天就拿一个非常简单的AD芯片,不参考任何别人的代码,手头能用的资料就是数据手册和原理图,写出它的驱动代码。我们的平台是stm32f407,AD芯片是ADS1118,裸机程序。假设硬件工程师已经做好了完整的硬件电路。

作为软件,我们最首先关心的是芯片各个引脚的描述,一下是数据手册中关于引脚的描述


这样一看我们就会发现,芯片对外的接口是非常常用的SPI接口,SPI的SCLK接SCLK,MOSI接DIN,MISO接DOUT。CS接普通IO口,VDD供电,有四路输入信号,AIN0-AIN4,通过描述可以发现,这四路可以接成单极性的四路输入,或者双极性的两路输入。看完这些我们基本明白了这些引脚的功能,大体明白了芯片如何与MCU连接(SPI和I2C接口是两种非常常用的接口,所以两种通信协议烂熟于心)。

这篇关于通过数据手册创造属于自己的代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1039351

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN