逻辑

概述  

在现代电子设计中,灵活性和高效性是关键。微控制器如配备了可配置逻辑模块 (CLB) ,可以满足了对片上数字逻辑的需求,无需使用外部逻辑芯片。这种高度灵活的逻辑单元,能够在不增加额外硬件的情况下,实现复杂的逻辑功能, 从而节省BOM成本和PCB空间。

这一集,Microchip的专家会为我们详细分享可配置逻辑模块(CLB)如何在微控制器(MCU)上实现比以往更大规模的硬件数字逻辑设计成为可能,并且它还能够在睡眠模式下运行,从而以极低的功耗进行复杂的处理。 

嘉宾介绍

1.png

吴涛 Tao Wu

MCU8产品部应用工程师

现于Microchip Technology Inc.(微芯科技公司)上海分公司任应用工程师。他于2022年加入Microchip,在嵌入式行业有着2年的工作经验。吴涛在嵌入式产品方面,有着丰富的研发及应用经验。他目前在Microchip负责8位单片机产品的应用。吴涛于2019年毕业于谢菲尔德大学,获得电子电气工程学士学位和计算机科学硕士学位。

什么是可配置逻辑模块?

可配置逻辑模块(CLB)是一种嵌入式逻辑单元,集成在微控制器或FPGA(现场可编程门阵列)中。它允许设计者通过软件配置,实现特定的逻辑功能,而无需额外的硬件电路。这种灵活性使得CLB在各种应用中都能发挥重要作用,从简单的逻辑控制到复杂的信号处理。

CLB的主要特点

1、灵活性:CLB可以通过软件进行配置,适应不同的应用需求。设计者可以根据具体的项目需求,快速调整逻辑功能。

2、高效性:由于CLB集成在微控制器或FPGA中,减少了外部硬件的需求,从而降低了系统的复杂性和成本。

3、可重配置性:CLB可以在运行时进行重新配置,使得系统能够动态适应不同的工作模式和条件。

4、低功耗:CLB的设计注重功耗优化,适用于对能耗敏感的应用场景。

CLB的应用领域

1、工业自动化:在工业控制系统中,CLB可以用于实现复杂的逻辑控制和信号处理,提高系统的响应速度和可靠性。

2、消费电子:在智能家居设备和可穿戴设备中,CLB可以实现灵活的逻辑控制,提升用户体验。

3、汽车电子:在汽车电子系统中,CLB可以用于实现实时信号处理和控制,提高车辆的安全性和性能。

4、通信系统:在通信设备中,CLB可以用于实现高速数据处理和传输,提高通信效率。

2.png

CLB的核心是32个互连的基本逻辑单元(BLEs)。每个BLE是一个4输入查找表,也称为LUTs,可以配置模拟各种逻辑门。输入和输出可以连接到MCU的其余部分。CLB还具有3位硬件计数器和边缘检测能力。

CLB外设包括16个输入源,将CLB连接到外部信号,并提供32个CLBSWIN信号与CPU交互。CLBSWIN信号是不同信号路由进入CLB进行处理的路径,并提供灵活性以根据应用程序的特定需求配置逻辑块。此外,所有配置值都由原理图合成器设置。

CLB可以包含多达32个基本逻辑单元,包括:

  • AND/OR/NAND/NOR门

  • 缓冲器/反向缓冲器

  • D触发器

  • JK触发器

  • 多路复用器

  • 4输入查找表(LUT)

可配置逻辑模块能实现的功能

3.png

应用机会及用例探究

  • 具有冗余配置的系统具

  • 有安全预防措施的系统

  • 空间敏感型应用

  • 取代分立式逻辑芯片, CPLD, 低端FPGA, 应用中组合使用的MCU + CPLD/FPGA

4.png

CLB合成器

CLB合成器是一个用于配置CLB的集成工具。与其设置50多个寄存器,不如通过图形化设计或编写Verilog代码,该工具会将其转换为CLB可以读取的配置。在运行时,CLB比特流使用CRC模块加载,以防止意外的配置更改。该工具集成在Microchip Code Configurator中,也可以作为独立工具在logic.microchip.com/clb上使用。

6.gif

6.png

PIC16F13145微控制器系列

凭借其专注的外设集,提供了一种有效的方法来实现基于硬件的解决方案。该设备系列引入了可配置逻辑模块(CLB)外设,使用户能够在其应用中加入基于硬件的自定义逻辑。7.png

结语

微芯科技的可配置逻辑模块(CLB)为电子设计提供了强大的工具,能够在不增加硬件复杂性的情况下,实现灵活、高效的逻辑功能。无论是在工业、消费电子、汽车还是通信领域,CLB都展现出了广泛的应用前景。通过合理利用CLB,设计者可以大幅提升系统的性能和可靠性,为现代电子设计注入新的活力。

小编的话

正如视频所介绍的,MCU中的可配置逻辑模块对数字逻辑设计具有多方面的价值。它们不仅提高了设计的灵活性和定制化程度,还优化了系统性能与响应时间,简化了设计流程缩短开发周期,同时还增强了系统的可升级性与可维护性。您对可配置逻辑模块的应用和设计有哪些经验或疑问?欢迎留言,分享交流!

来源:DigiKey电子技术台

免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理(联系邮箱:cathy@eetrend.com)。

围观 39

众所周知我们现在身处数字化的世界,那么究竟什么才是数字化呢?其实所谓的数字化就是以简单的0和1两个二进制数字为基础,对现实世界的各种数据进行搜集、存储、运算并显示的过程,而二进制中的0和1所依托的数字逻辑基础就是数字电路中两种基础状态。虽然我们自然界的各种元素都是模拟的,但信息化的社会已经离不开数字电路带来的0和1。

二进制是现在通用电子信息技术的运算基础,由于二进制仅有0和1两个基础数字,所以任何具有两个不同稳定状态的元件都可用二进制来表达,例如,电压的「高和低」、开关的「开和关」,电流的「正和负」等。一般来讲,利用数字来代表两种截然不同的状态是很容易实现的。在数字电路中,基本的逻辑门实现就直接应用了二进制,因此现代的计算机和依赖电路处理的设备里都延续了二进制的使用。

“【微控制器基础】——电路中的“数字与逻辑”(上)"

微控制器中常见的数字值

数字电路组成了芯片的基础,大部分具有数据处理和控制能力的芯片都是数字电路,目前最普遍的处理单元微控制器也不例外。微控制器借助数字电路提供的二进制数字0和1,能够理解「电压高低」、「电流是否流动」、「开还是关」等问题。

微控制器使用的数据是有单位的,当数据用二进制数表示时,一个数字称为一位。一般来讲,我们常见的微控制器可分为4位、8位或16位等,这些位数代表了在一个时钟周期内,微控制器所处理的二进制代码数。但值得注意的是,1K(Kilo)位是1024位,而不是1000位。

“【微控制器基础】——电路中的“数字与逻辑”(上)"

在二进制中,半字节(nibble)是一个4位的二进制数,代表1个半字节(4位)的数据。字节(byte)是一个8位的二进制数,代表1个字节(8位)的数据。此外,还可以使用“字”表示处理器所处理的数据。例如,在4位微控制器中,4位数据有时称为1个字;在16位微控制器中,16位数据有时称为1个字。因此,要提前查看在微控制器中1个字的位数是多少,以及如何处理它们。

除了二进制,在数据处理中,十进制与十六进制也是常见的数字值。下图为十进制数、二进制数和十六进制数的对比表。由于二进制数的4位可以用十六进制数中的1位来表示,所以通过采用十六进制数可以使二进制的数据处理起来很方便。

“【微控制器基础】——电路中的“数字与逻辑”(上)"

数字值之间的转换

若想将十进制转化为二进制,需要先用数字除以2,然后取余数,再逆序排列的方法。以十进制数100为例,首先要用100除以2。它能被50整除,余数为0。然后,用50除以2得到25,再用25除以2,去掉余数1,继续计算,直到不被整数除掉为止。计算结果的余数从下往上逆序排,便将其转换为了二进制数(1100100)。

“【微控制器基础】——电路中的“数字与逻辑”(上)"

那么如何转换为十六进制数呢?如果用100除以16,就是6,余数为4。因此,当十进制数100转换为十六进制数时,就变成了(64)。

“【微控制器基础】——电路中的“数字与逻辑”(上)"

无论是控制器还是处理器,无论是简单的单片机还是复杂的服务器,回归到最基础的部分就是这些由简单数字组成的算术单元。

来源:东芝半导体
免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理(联系邮箱:cathy@eetrend.com)。

围观 61
订阅 RSS - 逻辑