當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]實(shí)時(shí)操作系統(tǒng)uC/0S II下TCP/IP協(xié)議棧的實(shí)現(xiàn)

摘要:結(jié)合ez80和ARM7兩種系統(tǒng)上的具體實(shí)現(xiàn),說明了如何在嵌入式實(shí)時(shí)操作系統(tǒng)uC/0SII上移植實(shí)現(xiàn)LwIP這套TCP/IP協(xié)議棧,使uC/0S II成為支持網(wǎng)絡(luò)的RTOS。

1 引言

隨著嵌入式系統(tǒng)與網(wǎng)絡(luò)的日益結(jié)合,在嵌入式實(shí)時(shí)操作系統(tǒng)中引入TCP/IP協(xié)議棧,以支持嵌入式設(shè)備接入網(wǎng)絡(luò),成為嵌入式領(lǐng)域重要的研究方向。uC/0S II是近年來發(fā)展迅速的一個(gè)開放源碼實(shí)時(shí)操作系統(tǒng),但它只是一個(gè)實(shí)時(shí)的任務(wù)調(diào)度及通信內(nèi)核,缺少對(duì)外圍設(shè)備和接口的支持,如沒有文件系統(tǒng)、網(wǎng)絡(luò)協(xié)議、圖形界面。筆者在多個(gè)嵌入式項(xiàng)目的開發(fā)過程中,以開源TCP/IP協(xié)議棧LwIP為基礎(chǔ),給uC/0S II加上了網(wǎng)絡(luò)支持。下面就以u(píng)C/0S II +LwIP分別在8位MCU ez80和32位MCU ARM7TDMI上的實(shí)現(xiàn)為例進(jìn)行說明。

需要說明的是,筆者使用的ez80系統(tǒng)是Zilog公司的ez80190開發(fā)板,自帶網(wǎng)絡(luò)芯片。而ARM7系統(tǒng)是使用筆者參與開發(fā)的Skyeye,一個(gè)基于GDB的ARM7TDMI指令級(jí)軟件仿真器。Skyeye小組最近為Skyeye加上了軟件模擬的Ne2k兼容網(wǎng)絡(luò)芯片,可以運(yùn)行帶網(wǎng)絡(luò)支持的μcLinux和uC/0S II。以下的全部相關(guān)程序和代碼都可以在Skyeye網(wǎng)站(hpclab.cs.tsinghua.edu.cn/~skyeye/)下載。

2 基于uC/0S II的網(wǎng)絡(luò)平臺(tái)概述

嵌入式操作系統(tǒng)uC/0S II是一個(gè)公開源代碼的占先式多任務(wù)的微內(nèi)核RTOS,其性能和安全性可以與商業(yè)產(chǎn)品競(jìng)爭(zhēng)。uC/0S II的特點(diǎn)可以概括為以下幾個(gè)方面:公開源代碼,代碼結(jié)構(gòu)清晰、明了,注釋詳盡,組織有條理,可移植性好??刹眉簦晒袒?。內(nèi)核屬于搶占式,最多可以管理60個(gè)任務(wù)。uC/0S II自1992年的第一版(uC/0S)以來已經(jīng)有好幾百個(gè)應(yīng)用,是一個(gè)經(jīng)實(shí)踐證明好用且穩(wěn)定可靠的內(nèi)核。目前國(guó)內(nèi)對(duì)uC/0S II的研究和應(yīng)用都很多。

TCP/IP是Internet的基本協(xié)議,以其實(shí)用性、高效性已經(jīng)成為事實(shí)上的工業(yè)標(biāo)準(zhǔn)。嵌入式設(shè)備要與Internet網(wǎng)絡(luò)直接交換信息,就必須支持TCP/IP協(xié)議。目前嵌入式設(shè)備上TCP/IP方案有很多種,但面向低端應(yīng)用的開源嵌入式網(wǎng)絡(luò)平臺(tái)還很少見。

uC/0S II是一個(gè)富有開放色彩的RTOS,只要買一本書就可獲得源代碼,對(duì)學(xué)校和教育的使用完全免費(fèi),商業(yè)應(yīng)用的費(fèi)用相對(duì)也很低。但是它目前的一些第三方TCP/IP支持都是完全商業(yè)化的,用戶需要付費(fèi)才能獲得,很少給出源代碼,這影響了uC/0S II的研究和推廣。通過把開放源代碼的TCP/IP協(xié)議棧LwIP移植到uC/0S II上來,就獲得了一套可免費(fèi)研究、學(xué)習(xí)的嵌入式網(wǎng)絡(luò)軟件平臺(tái)。

3 開源TCP/IP協(xié)議棧LwIP簡(jiǎn)介

LwIP是瑞士計(jì)算機(jī)科學(xué)院(Swedish InSTitute of Computer Science)的Adam Dunkels等開發(fā)的一套用于嵌入式系統(tǒng)的開放源代碼TCP/IP協(xié)議棧。LwIP的含義是Light Weight(輕型)IP協(xié)議。LwIP可以移植到操作系統(tǒng)上,也可以在無操作系統(tǒng)的情況下獨(dú)立運(yùn)行。LwIP TCP/IP實(shí)現(xiàn)的重點(diǎn)是在保持TCP協(xié)議主要功能的基礎(chǔ)上減少對(duì)RAM的占用,一般它只需要幾十K的RAM和40K左右的ROM就可以運(yùn)行,這使LwIP協(xié)議棧適合在低端嵌入式系統(tǒng)中使用。

LwIP的特性如下:

(1) 支持多網(wǎng)絡(luò)接口下的IP轉(zhuǎn)發(fā)

(2) 支持ICMP協(xié)議

(3) 包括實(shí)驗(yàn)性擴(kuò)展的的UDP(用戶數(shù)據(jù)報(bào)協(xié)議)

(4) 包括阻塞控制,RTT估算和快速恢復(fù)和快速轉(zhuǎn)發(fā)的TCP(傳輸控制協(xié)議)

(5) 提供專門的內(nèi)部回調(diào)接口(Raw API)用于提高應(yīng)用程序性能

(6) 可選擇的Berkeley接口API(多線程情況下)

我們目前使用的是LwIP的最新穩(wěn)定版V0.5.3。有關(guān)LwIP的詳細(xì)內(nèi)容,可以參考其代碼和網(wǎng)站上的文檔。

4 LwIP在uC/0S II下的實(shí)現(xiàn)

4.1 概述

LwIP協(xié)議棧在設(shè)計(jì)時(shí)就考慮到了將來的移植問題,因此把所有與硬件、OS、編譯器相關(guān)的部份獨(dú)立出來,放在/src/arch目錄下。因此LwIP在uC/0S II上的實(shí)現(xiàn)就是修改這個(gè)目錄下的文件,其它的文件一般不應(yīng)該修改。下面分幾部份分別說明相應(yīng)文件的實(shí)現(xiàn)原理和過程。具體的代碼限于篇幅沒有給出,Skyeye網(wǎng)站上有完整的代碼和說明。

4.2 與CPU或編譯器相關(guān)的include文件

/src/arch/include/arch目錄下cc.h、CPU.h、perf.h中有一些與CPU或編譯器相關(guān)的定義,如數(shù)據(jù)長(zhǎng)度,字的高低位順序等。這應(yīng)該與用戶實(shí)現(xiàn)uC/0S II時(shí)定義的數(shù)據(jù)長(zhǎng)度等參數(shù)是一致的。

#define BYTE_ORDER LITTLE_ENDIAN //ARM7默認(rèn)為小端存儲(chǔ)系統(tǒng)

//數(shù)據(jù)類型長(zhǎng)度的定義

typedef unsigned char u8_t;

typedef signed char s8_t;

typedef unsigned short u16_t;

typedef signed short s16_t;

typedef unsigned int u32_t;

typedef signed int s32_t;

此外還有一點(diǎn):一般情況下C語言的結(jié)構(gòu)體struct是4字節(jié)對(duì)齊的,但是在處理數(shù)據(jù)包的時(shí)候,LwIP使用的是通過結(jié)構(gòu)體中不同數(shù)據(jù)的長(zhǎng)度來讀取相應(yīng)的數(shù)據(jù)的,所以,一定要在定義struct的時(shí)候使用_packed關(guān)鍵字,讓編譯器放棄struct的字節(jié)對(duì)齊。LwIP也考慮到了這個(gè)問題,所以,在它的結(jié)構(gòu)體定義中有幾個(gè)PACKED_FIELD_xxx宏,默認(rèn)的時(shí)候這幾個(gè)宏都是空的,可以在移植的時(shí)候添加不同的編譯器所對(duì)應(yīng)的_packed關(guān)鍵字。比如在Skyeye(ARM7)上對(duì)應(yīng)gcc編譯器的定義:

#define PACK_STRUCT_FIELD(x) x __attribute__((packed))

#define PACK_STRUCT_STRUCT __attribute__((packed))

#define PACK_STRUCT_BEGIN

#define PACK_STRUCT_END

4.3 sys_arch操作系統(tǒng)相關(guān)部份

sys_arch.[ch]中的內(nèi)容是與OS相關(guān)的一些結(jié)構(gòu)和函數(shù),主要可以分為四個(gè)部份:

(1) sys_sem_t 信號(hào)量

LwIP中需要使用信號(hào)量通信,所以在sys_arch中應(yīng)實(shí)現(xiàn)信號(hào)量結(jié)構(gòu)體和處理函數(shù):

struct sys_sem_t

sys_sem_new() //創(chuàng)建一個(gè)信號(hào)量結(jié)構(gòu)

sys_ sem _free() //釋放一個(gè)信號(hào)量結(jié)構(gòu)

sys_ sem _signal() //發(fā)送信號(hào)量

sys_ arch_sem _wait() //請(qǐng)求信號(hào)量

由于uC/0SII已經(jīng)實(shí)現(xiàn)了信號(hào)量OS_EVENT的各種操作,并且功能和LwIP上面幾個(gè)函數(shù)的目的功能是完全一樣的,所以只要把uC/0SII的函數(shù)重新包裝成上面的函數(shù),就可以直接使用了。

(2) sys_mbox_t 消息

LwIP使用消息隊(duì)列來緩沖、傳遞數(shù)據(jù)報(bào)文,因此要在sys_arch中實(shí)現(xiàn)消息隊(duì)列結(jié)構(gòu)sys_mbox_t,以及相應(yīng)的操作函數(shù):[!--empirenews.page--]

sys_mbox_new() //創(chuàng)建一個(gè)消息隊(duì)列

sys_mbox_free() //釋放一個(gè)消息隊(duì)列

sys_mbox_post() //向消息隊(duì)列發(fā)送消息

sys_arch_mbox_fetch() //從消息隊(duì)列中獲取消息

uC/0SII同樣實(shí)現(xiàn)了消息隊(duì)列結(jié)構(gòu)OSQ及其操作,但是uC/0SII沒有對(duì)消息隊(duì)列中的消息進(jìn)行管理,因此不能直接使用,必須在uC/0SII的基礎(chǔ)上重新實(shí)現(xiàn)。為了實(shí)現(xiàn)對(duì)消息的管理,我們定義了以下結(jié)構(gòu):

typedef struct {

OS_EVENT* pQ;

void* pvQEntries[MAX_QUEUE_ENTRIES];

} sys_mbox_t;

在以上結(jié)構(gòu)中,包括OS_EVENT類型的隊(duì)列指針(pQ)和隊(duì)列內(nèi)的消息(pvQEntries)兩部分,對(duì)隊(duì)列本身的管理利用uC/0SII自己的OSQ操作完成,然后使用uC/0SII中的內(nèi)存管理模塊實(shí)現(xiàn)對(duì)消息的創(chuàng)建、使用、刪除回收,兩部分綜合起來形成了LwIP的消息隊(duì)列功能。

(3) sys_arch_timeout 函數(shù)

LwIP中每個(gè)與外界網(wǎng)絡(luò)連接的線程都有自己的timeout屬性,即等待超時(shí)時(shí)間。這個(gè)屬性表現(xiàn)為每個(gè)線程都對(duì)應(yīng)一個(gè)sys_timeout結(jié)構(gòu)體隊(duì)列,包括這個(gè)線程的timeout時(shí)間長(zhǎng)度,以及超時(shí)后應(yīng)調(diào)用的timeout函數(shù),該函數(shù)會(huì)做一些釋放連接,回收資源的工作。如果一個(gè)線程對(duì)應(yīng)的sys_timeout為空(NULL),說明該線程對(duì)連接做永久的等待。

timeout結(jié)構(gòu)體已經(jīng)由LwIP自己在sys.h中定義好了,而且對(duì)結(jié)構(gòu)體隊(duì)列的數(shù)據(jù)操作也由LwIP負(fù)責(zé),我們所要實(shí)現(xiàn)的是如下函數(shù):

struct sys_timeouts * sys_arch_timeouts(void)

這個(gè)函數(shù)的功能是返回目前正處于運(yùn)行態(tài)的線程所對(duì)應(yīng)的timeout隊(duì)列指針。timeout隊(duì)列屬于線程的屬性,因此是OS相關(guān)的函數(shù),只能由用戶實(shí)現(xiàn)。

(4) sys_thread_new 創(chuàng)建新線程

LwIP可以是單線程運(yùn)行,即只有一個(gè)tcpip線程(tcpip_thread),負(fù)責(zé)處理所有的tcp/ucp連接,各種網(wǎng)絡(luò)程序都通過tcpip線程與網(wǎng)絡(luò)交互。但LwIP也可以多線程運(yùn)行,以提高效率,降低編程復(fù)雜度。這時(shí)就需要用戶實(shí)現(xiàn)創(chuàng)建新線程的函數(shù):

void sys_thread_new(void (* thread)(void *arg), void *arg);

在uC/0S II中,沒有線程(thread)的概念,只有任務(wù)(Task)。它已經(jīng)提供了創(chuàng)建新任務(wù)的系統(tǒng)API調(diào)用OSTaskCreate,因此只要把OSTaskCreate封裝一下,就可以實(shí)現(xiàn)sys_thread_new。需要注意的是LwIP中的thread并沒有uC/0S II中優(yōu)先級(jí)的概念,實(shí)現(xiàn)時(shí)要由用戶事先為L(zhǎng)wIP中創(chuàng)建的線程分配好優(yōu)先級(jí)。

4.4 lib_arch中庫函數(shù)的實(shí)現(xiàn)

LwIP協(xié)議棧中用到了8個(gè)外部函數(shù),這些函數(shù)通常與用戶使用的系統(tǒng)或編譯器有關(guān),因此留給用戶自己實(shí)現(xiàn)。如下:

u16_t htONs(u16_t n); //16位數(shù)據(jù)高低字節(jié)交換

u16_t ntohs(u16_t n);

u32_t htonl(u32_t n); //32位數(shù)據(jù)大小頭對(duì)調(diào)

u32_t ntohl(u32_t n);

int strlen(const char *str); //返回字符串長(zhǎng)度

int strncmp(const char *str1, const char *str2, int len); //字符串比較

void bcopy(const void *src, void *dest, int len); //內(nèi)存數(shù)據(jù)塊之間的互相拷貝

void bzero(void *data, int n); //內(nèi)存中指定長(zhǎng)度的數(shù)據(jù)塊清零

前四個(gè)函數(shù)通常由用戶自己實(shí)現(xiàn)。Skyeye(ARM7)中,由于使用了gcc編譯器,gcc的lib庫里已經(jīng)有了后四個(gè)函數(shù)。而ez80的編譯器函數(shù)庫中缺少bcopy和bzero兩個(gè),需要自己編寫。用戶在其它CPU上實(shí)現(xiàn)時(shí)應(yīng)根據(jù)自己的編譯器來決定。

4.5 網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)程序

ez80開發(fā)板自帶的網(wǎng)絡(luò)芯片為RealTek的8019as芯片,這是ISA 10BASE-T的以太網(wǎng)芯片,與Ne2k兼容。而我們?cè)贏T91模擬器Skyeye中所仿真的網(wǎng)絡(luò)芯片也是Ne2k,所以目前實(shí)現(xiàn)的網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)是針對(duì)Ne2k的,其它類型的網(wǎng)絡(luò)芯片驅(qū)動(dòng)可以在LwIP的網(wǎng)站上找到。LwIP的網(wǎng)絡(luò)驅(qū)動(dòng)有一定的模型,/src/netif/ethernetif.c 文件即為驅(qū)動(dòng)的模板,用戶為自己的網(wǎng)絡(luò)設(shè)備實(shí)現(xiàn)驅(qū)動(dòng)時(shí)應(yīng)參照此模板。

在LwIP中可以有多個(gè)網(wǎng)絡(luò)接口,每個(gè)網(wǎng)絡(luò)接口都對(duì)應(yīng)了一個(gè)struct netif,這個(gè)netif包含了相應(yīng)網(wǎng)絡(luò)接口的屬性、收發(fā)函數(shù)。LwIP調(diào)用netif的方法netif->input()及netif->output()進(jìn)行以太網(wǎng)packet的收、發(fā)等操作。在驅(qū)動(dòng)中主要做的,就是實(shí)現(xiàn)網(wǎng)絡(luò)接口的收、發(fā)、初始化以及中斷處理函數(shù)。驅(qū)動(dòng)程序工作在IP協(xié)議模型的網(wǎng)絡(luò)接口層,它提供給上層(IP層)的接口函數(shù)如下:

//網(wǎng)卡初始化函數(shù)

void ethernetif_init(struct netif *netif)

//網(wǎng)卡接收函數(shù),從網(wǎng)絡(luò)接口接收以太網(wǎng)數(shù)據(jù)包并把其中的IP報(bào)文向IP層發(fā)送

//在中斷方式下由網(wǎng)卡ISR調(diào)用

void ethernetif_input(struct netif *netif)

//網(wǎng)卡發(fā)送函數(shù),給IP層傳過來的IP報(bào)文加上以太網(wǎng)包頭并通過網(wǎng)絡(luò)接口發(fā)送

err_t ethernetif_output(struct netif *netif, struct pbuf *p, struct ip_addr *ipaddr)

//網(wǎng)卡中斷處理函數(shù)ISR

void ethernetif_isr(void);

以上的函數(shù)都可以分為協(xié)議棧本身的處理和對(duì)網(wǎng)絡(luò)接口硬件的操作兩部份,但硬件操作是對(duì)上層屏蔽的,具體參見RTL8019as、DM9008等Ne2k網(wǎng)絡(luò)芯片的數(shù)據(jù)手冊(cè)。驅(qū)動(dòng)程序可以到Skyeye或LwIP的網(wǎng)站下載。

5 應(yīng)用實(shí)例的建立和測(cè)試

做完上面的移植修改工作以后,就可以在uC/0SII中初始化LwIP,并創(chuàng)建TCP或UDP任務(wù)進(jìn)行測(cè)試了。這部份完全是C語言的實(shí)現(xiàn),因此這部份在ez80和ARM7上基本都是一樣的。值得注意的是LwIP的初始化必須在uC/0SII完全啟動(dòng)之后也就是在任務(wù)中進(jìn)行,因?yàn)樗某跏蓟玫搅诵盘?hào)量等OS相關(guān)的操作。關(guān)鍵部份的代碼和說明如下:

main(){

OSInit();

OSTaskCreate(lwip_init_task, &LineNo11, &lwip_init_stk[TASK_STK_SIZE-1], 0);

OSTaskCreate(usr_task,&LineNo12,&usr_stk[TASK_STK_SIZE-1],1);

OSStart();

}

主程序中創(chuàng)建了lwip_init_task初始化LwIP任務(wù)(優(yōu)先級(jí)0)和usr_task用戶任務(wù)(優(yōu)先級(jí)1)。lwip_init_task任務(wù)中除了初始化硬件時(shí)鐘和LwIP之外,還創(chuàng)建了tcpip_thread(優(yōu)先級(jí)5)和tcpecho_thread(優(yōu)先級(jí)6)。實(shí)際上tcpip_thread才是LwIP的主線程,多線程的Berkley API也是基于這個(gè)線程實(shí)現(xiàn)的,即上面的tcpecho_thread線程也要依靠tcpip_thread線程來與外界通信,這樣做的好處是編程簡(jiǎn)單,結(jié)構(gòu)清晰。[!--empirenews.page--]

實(shí)用Berkley API實(shí)現(xiàn)的tcpecho_thread是一個(gè)TCP echo服務(wù)器,*7號(hào)端口,程序框架如下:

void tcpecho_thread(void *arg){

conn = netconn_new(NETCONN_TCP); //創(chuàng)建新的連接標(biāo)識(shí)

netconn_bind(conn, NULL, 7); //綁定到7號(hào)端口

netconn_listen(conn); //開始*端口

while(1){

newconn = netconn_accept(conn); //接收外部到來的連接

buf = netconn_recv(newconn) //獲取數(shù)據(jù)

……. //處理數(shù)據(jù)

netconn_write(newconn, data, len, NETCONN_COPY); //發(fā)送數(shù)據(jù)

netconn_delete(newconn); //釋放本次連接

}

}

編譯運(yùn)行后,用ping ip地址命令可以得到ICMP reply響應(yīng)。用telnet ip地址 7(登錄7號(hào)端口)命令可以看到echo server的回顯效果。說明ARP、ICMP、IP、TCP協(xié)議都已正確運(yùn)行。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉