`
xpp02
  • 浏览: 1053796 次
社区版块
存档分类
最新评论

硬件模块设计思想

 
阅读更多

硬件模块设计">模块设计,顾名思义就是将各个不同的功能做成独立的模块。然后将各个模块组合成不同的产品。

对于一个公司硬件模块化设计,从设计之初,调试,到样机及产品生产的过程应该是这样:

1.     了解产品需求

2.     根据需求,选择合适的处理器

3.     根据处理器构架系统结构

4.     设计处理器的最小系统图,包括电源,晶振,不使用需要简单处理的引脚处理,将需要使用的引脚引出。

5.     选择和合适的成熟模块连接。

6.     与各个模块共同搭建一个开发平台。

7.     开发程序,调试。

8.     软件调试完毕,硬件功能完好。开始针对产品要求的体积,外形等进行修改,重新构建绘制原理图,pcb

9.     将程序下载到新的pcb中,进行必要的修改后,可以进行试验

10.   试验后根据情况再次进行修改。

11.   再次试验。

12.   没有问题后进行生产。

如果是单纯的生产一款产品,那么对于上述的4,5,6来讲没有必要这样做,这里的硬件模块化是针对公司的一个系列产品的设计进行构思的。

对于一个系列的产品,产品的功能有很多相似之处,往往高级的产品会比低级的产品多些功能,这样的话,这一系列的产品的有很多模块就是这一系列产品的特征,必须具有的,就像电话,一般都会具有接听,打出电话,发送,接收短消息这两个基本特征。但是这并不是说低级的产品是高级产品的子集,低级的产品功能有些也是高级产品所没有的。

为什么机械产品和电子器件的生产和使用及更换,在现在看来都很方便呢?很重要的一个问题就是大家在制作的时候都会遵循一个共同的标准。汽车出现了问题,我们不会重新将汽车生产一次,而是更换零件;汽车的升级换代,不是重新研发,而是现有基础上的改进和提高;即使是革命性的变化也不会将现有和以前的东西完全抛弃。

同样的道理一个板子上的芯片坏了,不是要换掉整个板子,而是将芯片换掉。

那么对于系列产品的开发,怎样才能方便的进行新产品初期的设计,调试,老产品的功能升级设计和调设呢?

待续。大家可以留言补充
我们接着上篇提出的问题继续讨论.

    现在大家对软件的模块设计">模块设计很熟悉 ,就是将软件的功能细分,然后做成一个独立的模块,不管用在哪里,只要告诉使用者接口和功能,就能很方便的使用.如果需要对函数进行变动的话也很简单,直接对函数本身做改动就可以了,只要接口和功能没有变化,而不会对函数的调用者有任何影响.即使对函数的接口有小的变化,如果能在开始设计的时候能预留的设计,那么也对整个函数的使用都不会产生很大的影响.
   
    对于同系列产品的硬件设计而言,变化的莫过于两个方面,功能模块 主cpu.
   1 功能模块的变化包括:功能模块的增加或者减少,功能模块自身的修改
   2 由于不同的考虑在实现同样功能的前提下进行主cpu的更替.

    对于各种功能集成在一起的硬件设计来说,这两种情况都会导致板子的原理图和pcb的重新绘制,对于没有改变的模块部分都要重新绘制pcb,对于修改的部分也不能依靠原来的硬件进行验证,这样导致了资源和时间的浪费,为什么这样说?

    对于同样功能的模块,没有重复利用,浪费了资源;对于同样功能的模块还需要花费重复绘制pcb是时间的浪费;更严重的时间浪费是不能利用现有的模块和资源对改变的部分进行较快的前期验证.举个例子,假设一个板子的功能由A+B+C+D+E组成,如果需要改变A,将A改成F,对于模块集成的设计方法来说,就要将重新绘制将原来的板子改成B+C+D+E+F,然后做成试验板,然后进行功能验证和调试,;如果我们能只是将A换成F,然后F在B+C+D+E资源的基础上进行调试的话就会减少设计的工作量,节省设计的时间,充分的利用了现有的资源,同时这种做法非常有利于调试,因为对于成熟模块来说,设计成熟,经过验证,在调试的时候可以尽快的排除,找到真正的问题.

    对了,我说清楚一点,就是功能集成的意思我是指,将一个系统各种功能的实现在一块或者两块pcb板上的那种做法,至少一块板上存在3,4中模块的那种.

    当然,对于硬件设计来讲,如果每一个模块都要独立设计,然后再连成一起,这样也未免太过,系统连接的插头越多,系统的可靠性就会越降低.就像电脑中的一级缓存和速度的关系,加大的一级缓存的确可以增加电脑的运行速度,但是一级缓存和速度的关系并非成正比,到某一个点上,加多一级缓存对速度的提高已经没有什么作用了,反而增加了系统的成本,只有达到缓存和速度的最佳比例时,才能将性价比调到最高.

    对于硬件模块设计">模块设计,我想也是这样,不一定要把每个模块都要独立设计,适当的进行功能模块的划分,将相似的部分划在一起,这样减少模块之间连接,也提高了系统的可靠性,同时提高的系统的模块化程度,为重复利用资源和节约设计周期提供了方便.

    尽管模块化的设计有很多好处,我的观点是,硬件模块化设计的方法,我觉得非常适合产品的研发阶段和模块很多的产品也适合生产阶段.
分享到:
评论

相关推荐

    基于ARM9的触摸屏控制器系统硬件模块设计与实现.pdf

    在硬件模块设计方面,文章首先介绍了系统硬件总体结构,包括处理器、存储器、输入输出接口、网络接口等基本组成部分,并强调了模块化和结构化设计思想的重要性。作者指出,硬件设计需要依据具体应用场景进行优化选择...

    基于FPGA的IP承载网损伤仪设计.pdf

    研究中采用的方法和硬件模块设计思想在仿真测试上得到了验证,显示出该方案具有良好的应用前景。 在IP承载网的性能评估中,通常需要关注以下几个方面:吞吐量、时延、丢包率和抖动。吞吐量是指在没有数据丢失的情况...

    C高级编程 基于模块化设计思想的C语言开发

    C语言是一个“古老”的编程工具。在嵌入式系统、自控系统及计算机底层操作系统、数据处理中间件等系统开发中仍然是优先...如果你想有效地使用C语言,在系统设计中灵活地应用模块化设计思想,本书是一个很不错的参考。

    基于单片机和CPLD共同控制的LED大屏幕显示系统的设计与实现

    系统硬件模块设计思想 ##### 3.1 基于CPLD的扫描控制模块 为了克服单片机速度限制带来的问题,系统在EPM3128ALC100中建立了1个32位FIFO、写地址和数据产生器、读地址产生器。这些组件共同构成了数据缓冲,使...

    模块化思想在嵌入式系统设计中的应用

    - 硬件层面:设计硬件模块,如处理器模块、存储模块、输入输出模块等。 4. **接口定义**:定义各个模块之间的通信协议和数据交换格式。 5. **测试与验证**:对每个模块进行单独测试,确保其功能正确无误;然后进行...

    简述一下模块化的思想

    模块化是一种设计思想,其主要目标是通过将系统划分为一系列可独立设计、制造、测试及维护的单元(模块),来提高系统的整体性能和可靠性。在机电一体化领域中,模块化设计不仅可以帮助设计者更好地理解和管理复杂...

    用类设计思想实现单片机软件的C程序模块

    在探讨如何使用类设计思想来实现单片机软件的C程序模块化时,首先需要明确类设计思想的基本概念及其在面向对象编程(OOP)中的作用。然后,我们将着重讨论如何将这种思想应用于C语言环境中,特别是针对资源受限的...

    嵌入式系统的软硬件协同设计

    嵌入式系统的软硬件协同设计是一种先进的系统设计思想,它与传统设计方法有着明显的不同。在传统设计方法中,通常是先进行硬件设计,然后再进行软件设计,这种模式存在诸多弊端,如设计周期长、开发成本高、难以充分...

    面向MCU的小型前后台系统 此项目的设计思想是:功能模块与硬件高度解耦,提高代码模块的可复用性

    此项目的设计思想是:功能模块与硬件高度解耦,提高代码模块的可复用性;不使用复杂的数据结构和语法以提高不同硬件平台和编译器之间的兼容性,实现工程在不同MCU之间的快速移植;提供实用稳定常用的功能模块,实现...

    硬件总体设计报告.zip

    这部分通常涉及到总线结构、模块化设计思想等。 3. **组件选择**:报告会列举出选用的各个硬件组件,如处理器型号、内存类型、硬盘类型等,并解释选择这些组件的原因,包括性能、成本、兼容性等方面的考虑。 4. **...

    GPS软件接收机的模块设计与信号处理.pdf

    ### GPS软件接收机的模块设计与信号处理 #### 摘要 本文主要探讨了GPS软件接收机的设计方法,特别是采用软件无线电技术实现模块化设计的过程。研究利用Zarlink公司的GP2015芯片对GPS射频信号进行下变频处理,并将...

    基于FPGA的卷积神经网络加速模块设计.pdf

    本文提出了一种基于FPGA的CNN加速模块设计,旨在解决资源受限硬件平台上的卷积运算加速问题。 在设计基于FPGA的CNN加速模块之前,首先需要了解FPGA的基本原理和特点。FPGA是一种可以通过编程改变其逻辑功能的集成...

    软硬件协同设计方法

    ### 软硬件协同设计方法概述 软硬件协同设计是一种重要的设计策略,旨在优化嵌入式系统的性能,通过综合考虑软件和硬件之间的交互作用来提高整个系统的效率和可靠性。本篇将详细介绍软硬件协同设计的基本概念、系统...

    捷普硬件设计说明书

    列出了构成产品的核心元器件及其主要功能,如处理器、存储器等,有助于理解硬件架构的设计思想。 以上内容是对《捷普硬件设计说明书》的关键知识点总结,通过这些信息可以较为全面地了解该硬件产品的设计特点和技术...

    单片机典型模块设计实例导航(第二版)程序

    《单片机典型模块设计实例导航(第二版)》是一本深入浅出的单片机应用教程,旨在通过丰富的实例帮助读者理解和掌握单片机设计的关键技术。此程序集包含了该书第二版中的所有示例代码,是学习和实践单片机编程的重要...

    单片机C语言骚操作__模块化思想__1.自动初始化

    本话题将探讨一种“骚操作”——如何运用模块化思想来实现单片机程序的自动初始化,这在优化代码结构、提高可读性和可维护性方面具有重要意义。 模块化编程是一种设计方法论,它提倡将复杂系统分解成一系列独立、可...

    基于FPGA的智能服务机器人图像预处理模块设计.pdf

    基于FPGA的智能服务机器人图像预处理模块设计涉及到了FPGA技术、图像处理算法、硬件设计、模块化设计思想以及Verilog HDL语言设计等多个技术领域。以下是对这些知识点的详细解读: 1. FPGA技术: FPGA(Field-...

    FPGA设计(设计思想与技巧)

    ### FPGA设计(设计思想...通过对面积与速度平衡的把握、遵循硬件和系统原则、采用有效的同步策略以及运用特定的设计思想与技巧,可以极大提升FPGA设计的质量和效率。希望以上内容能为您的FPGA设计之路提供有益的帮助。

    产品设计过程硬件开发.pdf

    本课程是关于产品设计过程的硬件开发,旨在帮助学员了解产品设计过程中各个环节,并树立按流程办事和流程优化思想。课程主要面向硬件研发类新员工,目标是让学员能够达到了解产品设计过程,并在实际工作中能够按流程...

    IP核芯志 数字逻辑设计思想

    数字逻辑设计思想部分,作者可能会探讨一些设计原则和最佳实践,如模块化设计、错误检测和纠正机制、可测试性设计(DFT),以及如何在设计早期进行性能和功耗的权衡分析。 通过阅读《IP核芯志:数字逻辑设计思想》...

Global site tag (gtag.js) - Google Analytics