女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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
    +關注

    關注

    5029

    文章

    13700

    瀏覽量

    471916
  • PC
    PC
    +關注

    關注

    9

    文章

    2142

    瀏覽量

    156015

原文標題:揭秘PLC背后的故事2

文章出處:【微信號:TopSemic,微信公眾號:TopSemic嵌入式】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    無刷電機電調的基本原理

    有關本文所談論的無刷電機內容, 只涉及低速飛行類航模電調的小功率無傳感器應用,講解的理論比較淺顯易懂 ,旨在讓初學者能夠對無刷電機有一個比較快的認 識,掌握基本原理和控制方法,可以在短時間內達到
    發表于 03-17 19:57

    RNN的基本原理實現

    RNN,即循環神經網絡(Recurrent Neural Network),是一種特殊類型的人工神經網絡,專門設計用于處理序列數據,如文本、語音、視頻等。以下是對RNN基本原理實現的介紹: 一
    的頭像 發表于 11-15 09:49 ?1241次閱讀

    混合鍵合的基本原理和優勢

    混合鍵合(Hybrid Bonding)是半導體封裝領域的新興技術,能夠實現高密度三維集成,無需傳統的焊料凸點。本文探討混合鍵合的基本原理、相比傳統方法的優勢,以及該領域的最新發展。
    的頭像 發表于 10-30 09:54 ?2251次閱讀
    混合鍵合的<b class='flag-5'>基本原理</b>和優勢

    Devops工具鏈集成的意義及基本原理

    Devops工具鏈集成的意義在于實現開發(Development)與運維(Operations)之間的緊密協作,通過自動化流程提高軟件交付的速度、質量和穩定性。其基本原理是通過一系列相互連接的工具,涵蓋從代碼編寫到部署、監控的全過程,促進團隊協作和效率提升。
    的頭像 發表于 10-14 10:32 ?437次閱讀

    可控硅觸發導通的基本原理

    可控硅觸發導通的基本原理涉及半導體器件的物理特性和電路控制邏輯,其核心在于通過外部信號(如電壓、電流或光信號)來觸發可控硅內部的PN結狀態變化,從而實現對主電路中電流的控制。
    的頭像 發表于 10-07 16:13 ?1408次閱讀

    高斯濾波的基本原理有哪些

    高斯濾波的基本原理可以從以下幾個方面進行闡述: 一、定義與性質 定義 :高斯濾波(Gaussian Filter)是一種常見的圖像處理技術,實質上是一種信號的濾波器,用于平滑和降噪圖像。它采用高斯
    的頭像 發表于 09-29 09:27 ?1352次閱讀

    3DP工藝基本原理

     3DP工藝,全稱Three-Dimensional Printing(三維打印),是一種3D打印技術,其基本原理可以詳細闡述如下:
    的頭像 發表于 09-16 15:32 ?1527次閱讀

    晶閘管觸發電路的基本原理和類型

    晶閘管觸發電路是電力電子技術中的重要組成部分,它負責控制晶閘管的導通與關斷,從而實現對電能的控制、調節和保護。以下是對晶閘管觸發電路的詳細解析,包括其基本原理、類型、設計要求、應用領域以及未來發展趨勢。
    的頭像 發表于 08-27 16:23 ?4245次閱讀

    濾波器的基本原理、分類及實現方式

    濾波器是一種信號處理設備,用于從信號中去除不需要的頻率成分,保留所需的頻率成分。在信號處理中,濾波器起著至關重要的作用。 濾波器的基本原理 濾波器的基本原理是利用信號的頻率特性來實現對信號的處理。在
    的頭像 發表于 08-25 14:44 ?1864次閱讀

    限流保護電路的基本原理

    限流保護電路的基本原理是一個復雜但至關重要的概念,它涉及到電子電路中電流控制的多個方面。這種電路的主要目的是在電流超過預設的安全閾值時,通過一系列機制來限制或切斷電流,從而保護電路中的元件和設備免受損壞。以下是對限流保護電路基本原理的詳細闡述,包括其工作機制、主要元件、設
    的頭像 發表于 08-19 17:55 ?3892次閱讀

    鉗表的基本原理與維護方法

    鉗表是一種常用的電流測量工具,今天小福將為您提供鉗表的基本原理、使用前的檢查、日常維護、錯誤操作的避免以及如何進行選型。
    的頭像 發表于 08-09 16:39 ?1810次閱讀
    鉗表的<b class='flag-5'>基本原理</b>與維護<b class='flag-5'>方法</b>

    無線充電技術的基本原理和應用領域

    無線充電技術作為近年來快速發展的電力傳輸方式,其基本原理和應用范圍廣泛,為人們的生活帶來了極大的便利。以下將詳細闡述無線充電技術的基本原理、主要類型、技術優勢以及在不同領域的應用。
    的頭像 發表于 07-26 17:56 ?4885次閱讀

    rnn神經網絡基本原理

    序列預測等領域有著廣泛的應用。本文將詳細介紹RNN的基本原理、結構、優化方法和應用場景。 RNN的基本原理 1.1 循環結構 RNN的核心思想是將前一個時間步的輸出作為下一個時間步的輸入,從而
    的頭像 發表于 07-04 15:02 ?1125次閱讀

    神經網絡的基本原理及Python編程實現

    神經網絡作為深度學習算法的基本構建模塊,模擬了人腦的行為,通過互相連接的節點(也稱為“神經元”)實現對輸入數據的處理、模式識別和結果預測等功能。本文將深入探討神經網絡的基本原理,并結合Python編程實現進行說明。
    的頭像 發表于 07-03 16:11 ?1296次閱讀

    神經網絡的基本原理

    神經網絡,作為人工智能領域的一個重要分支,其基本原理和運作機制一直是人們研究的熱點。神經網絡的基本原理基于對人類大腦神經元結構和功能的模擬,通過大量的神經元相互連接、協同工作,實現對信息的處理、分析
    的頭像 發表于 07-01 11:47 ?2161次閱讀