0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

PLC的基本原理和实现方法

TopSemic嵌入式 来源:工程师的废纸篓 作者:Tony Yang 2021-11-18 18:20 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

书接上回,我们上次以Codesys为例,介绍了其PC端的安装和Target配置,今天我们继续聊聊PLC的基本原理和实现方法。

突然想到之前有个重要的问题没有跟大家介绍,从实现方式上讲,PLC分编译型和解释型,Codesys是编译型的,而某宝上200多元的“三菱仿”是解释型的,其实这“三菱仿”某宝上20元就能买到全套原理图及PCB和源码。

这两条技术路线还是有比较大的区别,其中最大的区别就是IDE生成的文件是否可以在PLC设备端直接执行,编译型的可以直接运行,而解释型生成的是中间文件,其主要包含命令码和操作码,PLC在获取中间文件后会根据预先定义好的命令码来执行相应的操作。以后有时间我们分析下那20元的代码。今天我们先以编译型为例,来剖析其内部的工作原理

区别 编译型 解释型
执行效率
开发难度
跨平台运行
反编译源文件 一般
无扰下装
防克隆

1. 编译型PLC

编译型PLC本质上就是PC端IDE(如之前介绍的Codesys)生成的固件或者二进制文件可以直接在PLC设备端运行,这就要求PC端IDE要集成相关的编译器。为了更容易说明这个问题,我们以开源PLC软件Beremiz为例讲解:

Beremiz的上位机的核心由3部分组成:PLCOpen Editor,MatIEC,GCC

组件 功能
PLCOpen Editor 为用户提供编程界面和配置信息
MatIEC 将用户基于IEC61131-3程序转为C语言文件
GCC 将MatIEC转换的C文件编译链接为可执行的二进制代码或elf文件

Codesys对比Beremiz其实没有本质区别,可以理解为Codesys PC端 = PLCOpen Editor+MatIEC+GCC,核心过程是一致的,都是先将用户程序、配置信息编译到Image中,只是这个过程都在Codesys PC端内部处理了,并没有打开让用户看。不过,我们还是可以从一些文件中看到一些端倪。在Project目录中可以看到一个bin文件(不同的target目标文件不同)

用二进制工具打开后,可以看到如下内容,第一个字是保留字,第二个字是Image的地址,第三个字是初始化函数指针

不同的平台可以选择不同的编译器,在目标设置中可以看到它支持的处理器平台:

眼尖的小伙伴会看到Intel StrongARM,这是个什么鬼,Intel还有ARM产品么?还真有,Intel XScale系列产品是以ARMv4/ARMv5TE内核为基础的增强型ARM,不过后来停产了,由于ARM9用的ARMv4T内核与其指令兼容,所以理论上Codesys V2.x也是支持ARM9的。

2. Runtime System

Codesys/Beremiz编译好固件后是怎么运行在PLC设备端的呢?这就要请出今天的主角Runtime System(RTS)。由于没有公开的资料,所以只能以Beremiz为例向大家介绍其中的奥秘。下图就是RTS核心的一些功能:

PLC RTS 功能
IO 主要指CPU本体所带的IO通道,常见的有DI, DO, AI, AO, PWM, PTO, HCI等等
Dbg Server 主要用于和PC端通讯,获取下载用户程序,登录/注销调试模式,调试模式下读/写变量,示波器等功能
Library 库分两种,内部库是用户通过IEC61131编写的供其他用户使用,外部库是写在RTS中并提供头文件给PC端
User Code Interface RTS的主要功能,配合PC端来运行用户的程序
Backplane Bus 背板总线主要用于控制扩展的IO,常见的协议有Modbus、Profibus等等

RTS有一个非常简单的主循环,首先初始化MCU外设,然后加载用户代码并初始化变量,最后进入While(1)循环:IO输入->用户代码执行->IO输出->处理服务

2.1 User Code Interface

既然是用户接口,我们先来看看相关代码,Beremiz会将用户代码插入到对应的main.c中,然后进行编译:

接口是通过下面结构体与RTS进行交互的:

typedef struct
{
    uint32_t * sstart;
    app_fp_t entry;
    //App startup interface
    uint32_t * data_loadaddr;
    uint32_t * data_start;
    uint32_t * data_end;
    uint32_t * bss_end;
    app_fp_t * pa_start;
    app_fp_t * pa_end;
    app_fp_t * ia_start;
    app_fp_t * ia_end;
    app_fp_t * fia_start;
    app_fp_t * fia_end;
    //RTE Version control
    //Semantic versioning is used
    uint32_t rte_ver_major;
    uint32_t rte_ver_minor;
    uint32_t rte_ver_patch;
    //Hardware ID
    uint32_t hw_id;
    //IO manager data
    plc_loc_tbl_t * l_tab; //Location table
    uint32_t      * w_tab; //Weigth table
    uint16_t        l_sz;  //Location table size
    //Control instance of PLC_ID
    const char    * check_id; //Must be placed to the end of .text
    //App interface
    const char    * id;       //Must be placed near the start of .text

    int (*start)(int ,char **);
    int (*stop)(void);
    void (*run)(void);

    void (*dbg_resume)(void);
    void (*dbg_suspend)(int);

    int  (*dbg_data_get)(unsigned long *, unsigned long *, void **);
    void (*dbg_data_free)(void);

    void (*dbg_vars_reset)(void);
    void (*dbg_var_register)(int, void *);

    uint32_t (*log_cnt_get)(uint8_t);
    uint32_t (*log_msg_get)(uint8_t, uint32_t, char*, uint32_t, uint32_t*, uint32_t*, uint32_t*);
    void     (*log_cnt_reset)(void);
    int (*log_msg_post)(uint8_t, char*, uint32_t);
}
plc_app_abi_t;

初始化加载用户代码,PLC_APP_BASE就是用户Image在MCU中对应的Flash地址

uint8_t plc_load_app()
{
  uint8_t ret = 0;
  
  if(plc_app_is_valid())
  {
    plc_curr_app = ((plc_app_abi_t *)PLC_APP_BASE);
    plc_app_cstratup();
    ret = 1;
  }
  else
  {
    plc_curr_app = (plc_app_abi_t *)&plc_app_default;
    ret = 0;
  }
  
  return ret;
  
}

cstratup函数原型,其过程和MCU进main函数之前的初始化代码非常相似,清零bss段,全局变量赋值等等

void plc_app_cstratup(void)
{
  volatile uint32_t *src, *dst, *end;
  app_fp_t *func, *func_end;
  //Init .data
  dst = plc_curr_app->data_start;
  end = plc_curr_app->data_end;
  src = plc_curr_app->data_loadaddr;
  while (dst < end)
  {
    *dst++ = *src++;
  }
  //Init .bss
  end = plc_curr_app->bss_end;
  while (dst < end)
  {
    *dst++ = 0;
  }
  // Constructors
  // .preinit_array
  func = plc_curr_app->pa_start;
  func_end = plc_curr_app->pa_end;
  while (func < func_end)
  {
    (*func)();
    func++;
  }
  // .init_array
  func = plc_curr_app->ia_start;
  func_end = plc_curr_app->ia_end;
  while (func < func_end)
  {
    (*func)();
    func++;
  }
}

初始化完成后,已经可以进入while(1)了,通过plc_curr_app->run()函数指针就可以运行用户程序了

while (1)
{
  dbg_handler();
    
  if(plc_state == PLC_STATE_STARTED)
  {
    plc_iom_get();
    if((g_u64timer - before_iec) >= g_u64tick_period)
    {
plc_curr_app->run();
before_iec = g_u64timer;
}
    plc_iom_set();
  }
    
}

今天就写到这里吧,改天继续。

责任编辑:haq
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • plc
    plc
    +关注

    关注

    5052

    文章

    14803

    浏览量

    488518
  • PC
    PC
    +关注

    关注

    9

    文章

    2168

    浏览量

    159746

原文标题:揭秘PLC背后的故事2

文章出处:【微信号:TopSemic,微信公众号:TopSemic嵌入式】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    时钟芯片的基本原理及行业应用

    随着数智化社会的不断发展,时钟芯片作为数字电路中控制时间的核心部件,已经成为智能设备不可分割的一部分。本文将对时钟芯片的基本原理及行业应用进行详细的分析,帮助大家更好地了解这一领域的发展趋势。一
    的头像 发表于 03-17 15:53 6185次阅读
    时钟芯片的<b class='flag-5'>基本原理</b>及行业应用

    自适应滤波算法介绍之维纳滤波器的基本原理和应用示例

    前面我们介绍了匹配滤波器,本文将介绍维纳滤波器。首先我们回顾了维纳滤波的主人公Norbert Wiener,然后描述了维纳滤波的基本原理和推导,最后给出一个简单的维纳滤波应用。
    的头像 发表于 01-07 15:22 3112次阅读
    自适应滤波算法介绍之维纳滤波器的<b class='flag-5'>基本原理</b>和应用示例

    初识马达基本原理及组成部分

    电机分为发电机和电动机两类,马达通常指‌电动机‌,即利用电磁感应原理将电能转换为机械能的装置,常见于起动机、驱动系统等场景。‌ 以下是关于马达的详细介绍: 1.基本原理 马达的工作基于电磁感应定律
    的头像 发表于 01-05 09:32 926次阅读
    初识马达<b class='flag-5'>基本原理</b>及组成部分

    X-ray检查机的基本原理、主要类型和区别

    射线的穿透和差别吸收成像,但存在用途、设计标准和安全要求等方面差异。基本原理设备通过X射线管发射高能X射线,射线穿透被测物体,不同材料会对X射线产生不同程度的吸收
    的头像 发表于 12-27 14:25 541次阅读
    X-ray检查机的<b class='flag-5'>基本原理</b>、主要类型和区别

    PCB布局布线的相关基本原理和设计技巧

    1、PCB布局布线的相关基本原理和设计技巧 1、[问] 高频信号布线时要注意哪些问题? [答 ] 信号线的阻抗匹配; 与其他信号线的空间隔离; 对于数字高频信号,差分线效果会更好。 2
    发表于 11-14 06:11

    基于级联分类器的人脸检测基本原理

    本次分享的内容是基于级联分类器的人脸检测基本原理 1) 人脸检测概述 关于人脸检测算法,目前主流方法分为两类,一类是基于知识,主要方法包括模板匹配,人脸特征,形状和边缘,纹理特征,颜色特征
    发表于 10-30 06:14

    简述冲击电压发生器的基本原理

    冲击电压发生器的基本原理是 “电容并联充电、串联放电”,核心流程分三步: 先通过整流电路,将工频交流电转换为直流电,给多组电容器并联充电,储存足够电能并达到设定电压; 当充电完成后,触发高压开关使
    发表于 10-17 14:10

    NAND Flash的基本原理和结构

    NAND Flash是什么?NAND Flash(闪存)是一种非易失性存储器技术,主要用于数据存储。与传统的DRAM或SRAM不同,NAND Flash在断电后仍能保存数据。它通过电荷的存储与释放来实现数据的存储。
    的头像 发表于 09-08 09:51 7758次阅读
    NAND Flash的<b class='flag-5'>基本原理</b>和结构

    单相调压器和三相调压器的基本原理与主要结构

    调压器在电力系统中扮演着至关重要的角色,无论是单相调压器还是三相调压器,它们都在各自的应用场景中发挥着调节电压、稳定电力、保护设备的作用,了解这两种调压器的基本原理与主要结构,对于电力系统的设计和运维具有重要意义。本文将和大家一起探讨单相调压器和三相调压器的基本原理与主要
    的头像 发表于 08-05 15:27 1458次阅读

    如何实现PLC与HMI通讯

    在工业自动化行业中PLC和HMI这俩个可是黄金搭档,PLC在那HMI就在那几乎都是形影不离的。现场操作人员通过HMI可以直观的看到现场的产量,设备的状态信息。那这一效果是怎么实现的?
    的头像 发表于 07-10 15:39 1951次阅读
    如何<b class='flag-5'>实现</b><b class='flag-5'>PLC</b>与HMI通讯

    射频功率放大器的基本原理和组成部分

    在现代通信技术中,射频功率放大器(RF PA)是不可或缺的关键组件。它在无线通信设备中扮演着至关重要的角色,负责将微弱的射频信号放大到足够的功率,以便通过天线发射出去。本文将深入探讨射频功率放大器的基本原理、技术指标、分类、电路组成以及面临的挑战,帮助读者更好地理解其在通信系统中的重要性。
    的头像 发表于 07-10 11:05 3305次阅读
    射频功率放大器的<b class='flag-5'>基本原理</b>和组成部分

    微加工激光蚀刻技术的基本原理及特点

    特殊工艺(如高温键合、溅射、电镀等)形成金属导电层(通常为铜箔),并经激光蚀刻、钻孔等微加工技术制成精密电路的电子封装核心材料。它兼具陶瓷的优异物理特性和金属的导电能力,是高端功率电子器件的关键载体。下面我们将通过基本原理及特性、工艺对比、工艺价值等方向进行拓展。
    的头像 发表于 06-20 09:09 2313次阅读

    POE供电的基本原理,网络变压器的作用 网变的POE供电

    。网络变压器作为POE供电系统中的关键组件,其接线方式和设计对系统的性能和可靠性起着至关重要的作用。本文将详细探讨网络变压器在POE供电中的不同接线方式,包括空闲对供电和数据对供电的特点、差异以及布线要求。 一、POE供电的基本原理 POE技术的核心在于通过
    的头像 发表于 06-07 15:51 2299次阅读
    POE供电的<b class='flag-5'>基本原理</b>,网络变压器的作用 网变的POE供电

    了解信号完整性的基本原理

    ,设计人员必须注意电路板布局并使用适当的导线和连接器,从而最大限度地减少反射、噪声和串扰。此外,还必须了解传输线、阻抗、回波损耗和共振等基本原理。 本文将介绍讨论信号完整性时使用的一些术语,以及设计人员需要考虑的问题,然后介绍 [Amphenol] 优异的电缆和
    的头像 发表于 05-25 11:54 1597次阅读
    了解信号完整性的<b class='flag-5'>基本原理</b>

    定向自组装光刻技术的基本原理实现方法

    定向自组装光刻技术通过材料科学与自组装工艺的深度融合,正在重构纳米制造的工艺组成。主要内容包含图形结构外延法、化学外延法及图形转移技术。
    的头像 发表于 05-21 15:24 2573次阅读
    定向自组装光刻技术的<b class='flag-5'>基本原理</b>和<b class='flag-5'>实现</b><b class='flag-5'>方法</b>