hardware simulation——框架搭建

2024-01-14 09:44

本文主要是介绍hardware simulation——框架搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

引子

代码风格约束

代码结构和模板


引子

前几天有人拿个word文档,问我怎么实现,概括一下就是用c实现数码管显示。

 但是咱们肯定不做这么简单这么点,我打算做个开源的项目,可以一直更新底层软件库,和上层显示库,目标就是所有的硬件都能模拟。今天主要是搭建个框架,视频在B站。

000代码框架搭建_哔哩哔哩_bilibili

        我给他放到码云上了,录视频的时候开源协议没选,加上git命令太久没用生疏了,commit没推上去,现在好啦。等他初步可以用的时候我在开源。

代码风格约束

今天没想好,后面会逐步更新,暂时只有三点要求

1.注释必须使用/**/,且注释中不能包含注释

2.所有的缩进必须使用空格

3.每个文件要按照样例文件创建

4.==判断时常量在左变量在右

5.函数明变量名等长度不可以超过32个

6.宏定义必须大写

7.宏定义要用()

8.复杂宏定义需要使用do{}while(0)

        为什么要这样要求呢,首先注释用//的话,如果你的编辑器宽度不够,换个环境你的一行长注释可能会变成两行,这样编译时会报错的。

        缩进用空格则是因为tab不是在所有环境中都是四个空格的,会导致代码外观上很奇怪,另外有些文本工具可能没有tab解析。咱们为了体现专业性,所有的缩进都必须使用空格。

        文件样理后面解释

        我们有时在做等于判断时可能会漏下一个等号导致变成赋值操作,这样很不好。为了防止这种问题出现,可以把常量写左面。这样漏写时一编译就会检查出来。

        函数名变量名不超过32个其实也是为了优化效率,因为这个名字在程序执行阶段是会被用到的。名字过长就会影响效率,严重还会导致程序执行不了,超过硬件能访问的宽度了他可能会没法成功匹配正确的函数和变量。当然这个不是一一对应的,不是32个字符就对应32位。不是这样的。但是也右一定关系,所以最好别太长了。

        宏定义大写就是一个规范,这样你用的时候一下就知道他是个宏。

        宏定义必须用括号这个就比较有意思了举个例子

#define A(a) a*aint b = A(1+1);

当你没用括号时

b的值是1+1*1+1=3

但是其实你真正想的是4对吧

那就要这样

#define A(a) (a)*(a)

但是这样还是有问题,比如我要拿这个去计算时

#define a   1 + 1int b = a;

会只拿一个1,所以也要加括号

#define a   (1 + 1)int b = a;

当然我只是举个例子。正常不会这么简单

还有就是这种

#define INIT (0)
#define RES  (1)

        经常会看到很多寄存器会这样写,这个我不清楚为什么可能是为了统一代码风格,要是有知道的兄弟欢迎评论区来说说哈。

        然后就是do while这种就是因为有些宏要定义的比较复杂。

#include <stdio.h>  #define INT_TO_CHARS(n)    do{ \((n) >> 24 & 0xFF);\((n) >> 16 & 0xFF);\((n) >> 8 & 0xFF);\((n) & 0xFF);\
}while(0);int main() {  int num = 12345;  char chars[4];  // 使用宏将整型数拆分为四个char  chars[0] = INT_TO_CHARS(num)[0];  chars[1] = INT_TO_CHARS(num)[1];  chars[2] = INT_TO_CHARS(num)[2];  chars[3] = INT_TO_CHARS(num)[3];  printf("Chars: %c%c%c%c\n", chars[0], chars[1], chars[2], chars[3]);  return 0;  
}

为了保证定义的宏后面内容是个整体所以还要用\保证他们是一行的。

代码结构和模板

        暂时就是这样一个简单结构后面在继续丰富,我目前分三层,底层hardware,应用层APP和显示层show。

/*FILENAME:    main.c*DESC    :    program entry*AUTHOR  :    tianyu.xin**/

文件头每个文件都要有,这个后面继续补充描述项

/*FILENAME:    template.c*DESC    :    template Head file*AUTHOR  :    tianyu.xin**//* 62* */
/**************************************************************
***************************EXTERN******************************
**************************************************************//**************************************************************
***************************LOCAL******************************
**************************************************************/
#ifndef __TEMPLATE_H__
#define __TEMPLATE_H__
/*FILENAME:    template.c*DESC    :    template Head file*AUTHOR  :    tianyu.xin**//**************************************************************
***************************DEFINE******************************
**************************************************************//**************************************************************
***************************EXTERN******************************
**************************************************************//**************************************************************
***************************LOCAL******************************
**************************************************************/#endif /*template.h*/

local区存放本地函数,extern区存放针对本文件以外的对外接口

DEFINE是宏定义的区域

目前build还有很多问题,先用make后面用python做build过程。

目前python脚本支持清除工作。

import subprocess  
import sys  
import os  
import glob# 获取当前目录的绝对路径  
current_directory = os.getcwd()
output = current_directory+"/OUTPUT/"# 打印当前目录的路径  
print("当前目录的路径是:", current_directory)def compile_makefile():  """编译Makefile"""  subprocess.run(["make"])  # def clean():  
#     """清除Makefile编译的产物"""  
#     subprocess.run(["rm", output+"*"], shell=True)def clean():  """清除Makefile编译的产物"""  files_to_delete = glob.glob(output + "*")for file in files_to_delete:os.remove(file)if __name__ == "__main__":  if len(sys.argv) < 2:  pass#print("请输入命令参数:make 或 clean")elif sys.argv[1] == "make":  compile_makefile()  elif sys.argv[1] == "clean":  clean()  else:  print("无效的命令参数")

这篇关于hardware simulation——框架搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF