前言
本系列文章將以RTA-OS為例詳細(xì)介紹AUTOSAR OS標(biāo)準(zhǔn)及概念,并分享實(shí)際使用的一些案例,本文為符合AUTOSAR標(biāo)準(zhǔn)的RTA-OS功能簡(jiǎn)介。
正文
1.Introduction
RTA-OS是一種靜態(tài)可配置的搶占式實(shí)時(shí)操作系統(tǒng)(RTOS),用于高性能、資源受限的應(yīng)用程序。RTA-OS是開(kāi)放標(biāo)準(zhǔn)AUTOSAR R3,AUTOSAR R4.0(包括多核),AUTOSAR R4.1, AUTOSAR R4.2, AUTOSAR R4.3, AUTOSAR R4.4和AUTOSAR R4.5 (R19-11)操作系統(tǒng)規(guī)范的完整實(shí)現(xiàn),也完全符合OSEK/VDX操作系統(tǒng)標(biāo)準(zhǔn)版本2.2.3。OSEK現(xiàn)已在ISO 17356中標(biāo)準(zhǔn)化。
RTA-OS內(nèi)核被設(shè)計(jì)成:
high performance(高性能): 內(nèi)核非常小,速度非常快。內(nèi)核的內(nèi)存占用及其運(yùn)行時(shí)性能是同類OS中領(lǐng)先的,使得RTA-OS特別適用于大量制造的系統(tǒng),在這些系統(tǒng)中,必須滿足對(duì)硬件成本的非常嚴(yán)格的限制,并且任何最終產(chǎn)品都必須正確運(yùn)行。
RTA-OS提供了許多獨(dú)特的優(yōu)化,有助于降低系統(tǒng)的單位成本。內(nèi)核對(duì)所有類型的任務(wù)都使用了單堆棧體系結(jié)構(gòu)。與傳統(tǒng)的每個(gè)任務(wù)的堆棧模型相比,這節(jié)省了大量的RAM。此外,仔細(xì)的應(yīng)用程序設(shè)計(jì)可以利用單堆棧體系結(jié)構(gòu)來(lái)提供顯著的堆棧RAM節(jié)省。
離線工具分析您的操作系統(tǒng)配置,并使用這些信息構(gòu)建盡可能小且最快的內(nèi)核。您不打算使用的代碼被排除在內(nèi)核之外,以避免浪費(fèi)執(zhí)行時(shí)間和內(nèi)存空間。
real-time(實(shí)時(shí)): 傳統(tǒng)的RTOS設(shè)計(jì)通常具有不可預(yù)測(cè)的開(kāi)銷,通常取決于任務(wù)的數(shù)量和系統(tǒng)在每個(gè)時(shí)間點(diǎn)的狀態(tài)。這使得保證實(shí)時(shí)可預(yù)測(cè)性變得困難——無(wú)論內(nèi)核有多“快”。在RTA-OS中,內(nèi)核是快速的,而且所有的運(yùn)行時(shí)開(kāi)銷——比如切換任務(wù)、處理中斷和喚醒任務(wù)——都有較低的最壞情況邊界,執(zhí)行時(shí)間很少或沒(méi)有變化。在許多情況下,上下文切換發(fā)生在恒定的執(zhí)行時(shí)間內(nèi),這意味著RTA-OS可以用于開(kāi)發(fā)硬實(shí)時(shí)系統(tǒng),其中必須在特定的時(shí)間期限內(nèi)做出響應(yīng)。滿足嚴(yán)格的截止日期包括計(jì)算每個(gè)任務(wù)和中斷服務(wù)例程(ISR)的最壞情況響應(yīng)時(shí)間,并確保每次都按時(shí)運(yùn)行。RTA-OS是一個(gè)真正的RTOS,因?yàn)樗鼭M足了固定優(yōu)先級(jí)可調(diào)度性分析的假設(shè)。
portable(可移植性): RTA-OS可用于各種各樣的微控制器/編譯器組合(or port)。所有端口共享相同的公共RTA-OS代碼,這約占總內(nèi)核功能的97%。該內(nèi)核是用與MISRA-C 2012兼容的ANSI C編寫的。通過(guò)離線工具,可以生成RTA-OS的MISRA報(bào)告。
RTA-OS盡可能地不會(huì)對(duì)硬件施加控制。一般來(lái)說(shuō),不需要移交對(duì)硬件的控制,比如緩存、監(jiān)視器計(jì)時(shí)器和I/O端口。因此,您的代碼可以自由地使用硬件,從而允許將遺留軟件集成到系統(tǒng)中。
圖1.1:RTA-OS Product Architecture
RTA-OS產(chǎn)品體系結(jié)構(gòu)如圖1.1所示,它包括:
lrtaoscfg是一個(gè)圖形配置工具,它用自動(dòng)sarXML配置語(yǔ)言讀取和寫配置。
lrtaosgen是一個(gè)命令行工具,用于從輸入配置生成RTA-OS內(nèi)核庫(kù)。
l端口插件,一個(gè)用于您使用RTA-OS的每個(gè)目標(biāo)/編譯器組合。您可以同時(shí)安裝多個(gè)端口,并根據(jù)需要在它們之間進(jìn)行切換。您還可以同時(shí)安裝同一端口的多個(gè)版本,從而允許您輕松地管理使用遺留編譯器和/或微控制器的項(xiàng)目。
VRTA是一個(gè)特殊的端口插件,在標(biāo)準(zhǔn)Windows PC上提供RTA-OS功能。這允許您在不需要實(shí)際目標(biāo)硬件的情況下設(shè)計(jì)和測(cè)試應(yīng)用程序行為。VRTA提供了一個(gè)開(kāi)發(fā)工具包,允許您構(gòu)建虛擬ecu,可以模擬中斷,I/O等。
VRTA可用于模擬多核AUTOSAR應(yīng)用程序。
1.1 Features of the RTA-OS Kernel
RTA-OS基于早期ETAS操作系統(tǒng)的成熟技術(shù),迄今為止,該操作系統(tǒng)已在全球超過(guò)3.5億個(gè)ecu中使用。內(nèi)核提供了AUTOSAR R3.x,AUTOSAR R4.0, AUTOSAR R4.1, AUTOSAR R4.2, AUTOSAR R4.3, AUTOSAR R4.4和AUTOSAR R4.5 (R19-11)開(kāi)放標(biāo)準(zhǔn)的實(shí)現(xiàn)。這些標(biāo)準(zhǔn)從早期的OSEK OS標(biāo)準(zhǔn)中提取了功能。內(nèi)核還提供了許多RTA-OS獨(dú)有的附加特性。下面幾節(jié)簡(jiǎn)要介紹了這些標(biāo)準(zhǔn)及其特性。
1.1.1OSEK
OSEK是歐洲汽車行業(yè)標(biāo)準(zhǔn),致力于為汽車電子產(chǎn)品生產(chǎn)開(kāi)放系統(tǒng)接口。該項(xiàng)目的全名為OSEK/VDX。OSEK是由德語(yǔ)中的一個(gè)短語(yǔ)組成的首字母縮寫,翻譯為汽車電子產(chǎn)品的開(kāi)放系統(tǒng)和相應(yīng)的接口。VDX基于法國(guó)標(biāo)準(zhǔn)(車輛分布式執(zhí)行),現(xiàn)在已與OSEK合并。OSEK/VDX在本指南中被稱為OSEK。
OSEK的目標(biāo)是支持跨多個(gè)項(xiàng)目的軟件組件的可移植性和可重用性。這使得供應(yīng)商可以專注于汽車知識(shí)產(chǎn)權(quán),因此供應(yīng)商可以開(kāi)發(fā)純軟件解決方案,并在任何符合osek的ECU中運(yùn)行軟件。
然而,為了達(dá)到這個(gè)目標(biāo),需要對(duì)每個(gè)非應(yīng)用程序特定組件的接口進(jìn)行詳細(xì)的規(guī)范。因此,OSEK標(biāo)準(zhǔn)包括一個(gè)應(yīng)用程序編程接口(API),它從底層硬件和車載網(wǎng)絡(luò)配置的具體細(xì)節(jié)中抽象出來(lái)。
OSEK OS
OSEK操作系統(tǒng)是OSEK標(biāo)準(zhǔn)中最成熟和應(yīng)用最廣泛的一種。OSEK操作系統(tǒng)已被應(yīng)用于所有類型的汽車ecu中,從動(dòng)力系統(tǒng)、底盤和車身到多媒體設(shè)備。
OSEK操作系統(tǒng)的最新版本是2.2.3,這是2001年9月最初引入的2.2標(biāo)準(zhǔn)的第三個(gè)小版本。這個(gè)版本的OSEK OS也是ISO17356標(biāo)準(zhǔn)的一部分。
OSEK OS完全使用一種稱為OIL(OSEK實(shí)現(xiàn)語(yǔ)言)的離線配置語(yǔ)言進(jìn)行靜態(tài)定義。由于所有對(duì)象在系統(tǒng)生成時(shí)都是已知的,因此實(shí)現(xiàn)可以非常小和高效。
OSEK操作系統(tǒng)提供了以下操作系統(tǒng)功能:
任務(wù)(Task)是OSEK操作系統(tǒng)系統(tǒng)的主要組成部分。與其他操作系統(tǒng)不同的是,OSEK中的任務(wù)不需要自我調(diào)度(也就是說(shuō),不需要將任務(wù)的主體放在一個(gè)無(wú)限循環(huán)3中)。在OSEK操作系統(tǒng)中有四種類型的任務(wù):
l具有唯一優(yōu)先級(jí)和非排隊(duì)激活的基本任務(wù)(Basic taskswith unique priority and non-queued activation)。這些都是最簡(jiǎn)單的任務(wù)形式,非常適合用于硬實(shí)時(shí)系統(tǒng)。一旦任務(wù)被激活,它必須運(yùn)行并終止,然后才能再次被激活。這種類型的任務(wù)不能在執(zhí)行中途掛起自己以等待事件。在RTA-OS中,這些任務(wù)被稱為BCC1任務(wù),因?yàn)樗鼈儗?duì)應(yīng)于OSEK OS的BCC1一致性類(conformance class)(有關(guān)OSEK的一致性類的更多細(xì)節(jié),請(qǐng)參閱第4.3節(jié))。
l具有共享優(yōu)先級(jí)和排隊(duì)激活的基本任務(wù)(Basic taskswith shared priority and queued activation)。這些任務(wù)可以與系統(tǒng)中的其他任務(wù)共享優(yōu)先級(jí),并且在再次被激活之前不需要終止。操作系統(tǒng)排隊(duì)等待任務(wù)激活的隊(duì)列,并在當(dāng)前激活終止時(shí)運(yùn)行下一次激活。與BCC1任務(wù)一樣,這種類型的任務(wù)不能在執(zhí)行過(guò)程中掛起自己以等待事件。在RTA-OS中,這些任務(wù)被稱為BCC2任務(wù),因?yàn)樗鼈儗?duì)應(yīng)于OSEK OS的BCC2一致性類。
l具有唯一優(yōu)先級(jí)的擴(kuò)展任務(wù)(Extended taskswith unique priorit)。允許擴(kuò)展任務(wù)在執(zhí)行過(guò)程中等待事件(即,該任務(wù)可以自掛起)。但是,激活不能被排隊(duì),并且任務(wù)必須具有唯一的優(yōu)先級(jí)。在RTA-OS中,這些任務(wù)被稱為ECC1任務(wù),因?yàn)樗鼈儗?duì)應(yīng)于OSEK OS的ECC1一致性類。
l具有共享優(yōu)先級(jí)的擴(kuò)展任務(wù)(Extended tasks with shared priority.)。這些任務(wù)類似于ECC1任務(wù),但可以與系統(tǒng)中的其他任務(wù)共享優(yōu)先級(jí)。在這方面,它們類似于BCC2的任務(wù)。然而,與BCC2任務(wù)不同的是,擴(kuò)展任務(wù)不能有排隊(duì)激活。在RTA-OS中,這些任務(wù)被稱為ECC2任務(wù)。
系統(tǒng)可以包含上述任務(wù)類型的任何組合。
調(diào)度(Scheduling)任務(wù)可以預(yù)先調(diào)度或非預(yù)先調(diào)度,并且可以很容易地構(gòu)建協(xié)作調(diào)度器。
中斷(Interrupts)允許操作系統(tǒng)與異步外部觸發(fā)器的交互。
在OSEK OS中有兩種類型的中斷:
1.第一類中斷(Category 1 interrupts)不由操作系統(tǒng)處理;
2.第二類中斷(Category 2 interrupts)是由操作系統(tǒng)處理,并可以與之交互。
資源(Resources)是簡(jiǎn)單的二進(jìn)制信號(hào)量,允許在任務(wù)和中斷之間共享的臨界區(qū)上提供互斥。資源由操作系統(tǒng)使用優(yōu)先級(jí)天花板協(xié)議進(jìn)行管理,該協(xié)議保證不出現(xiàn)死鎖,并最大限度地減少運(yùn)行時(shí)的優(yōu)先級(jí)反轉(zhuǎn)。
Note: 優(yōu)先級(jí)反轉(zhuǎn)是指低優(yōu)先級(jí)任務(wù)優(yōu)先于高優(yōu)先級(jí)任務(wù)運(yùn)行的情況。使用優(yōu)先級(jí)上限協(xié)議,這種情況最多在高優(yōu)先級(jí)任務(wù)被激活時(shí)發(fā)生一次(并且總是在執(zhí)行開(kāi)始),并被稱為高優(yōu)先級(jí)任務(wù)的阻塞時(shí)間。阻塞時(shí)間受限于任何單個(gè)任務(wù)與高優(yōu)先級(jí)對(duì)象共享數(shù)據(jù)的最長(zhǎng)時(shí)間——由于低優(yōu)先級(jí)任務(wù)的交互而不存在累積阻塞。
計(jì)數(shù)器和告警(Counters and alarms)用于提供周期性(和非周期性)的任務(wù)調(diào)度。計(jì)數(shù)器,顧名思義,計(jì)數(shù)(domain specific)事件的發(fā)生,并將值寄存器為“ticks”。可以將告警設(shè)置為運(yùn)行時(shí)可配置的計(jì)數(shù)值,可以是絕對(duì)計(jì)數(shù)值,也可以是設(shè)置告警時(shí)相對(duì)于計(jì)數(shù)器的“tick”值。
調(diào)試支持(Debugging Support)通過(guò)使用構(gòu)建級(jí)別在操作系統(tǒng)中提供。操作系統(tǒng)提供了兩種構(gòu)建級(jí)別:
1.標(biāo)準(zhǔn)(Standard)是“精簡(jiǎn)和平均”,并提供最小的錯(cuò)誤處理。
2.擴(kuò)展(Extended)是“調(diào)試”版本,它提供了廣泛的錯(cuò)誤檢測(cè)功能,以檢查是否正確使用操作系統(tǒng)。
調(diào)試也通過(guò)OSEK ORTI (OSEK運(yùn)行時(shí)接口)標(biāo)準(zhǔn)提供。這為操作系統(tǒng)實(shí)現(xiàn)提供了一種通用的方法,可以將符號(hào)詳細(xì)信息導(dǎo)出到第三方調(diào)試器,以便調(diào)試器可以在運(yùn)行時(shí)顯示關(guān)于操作系統(tǒng)內(nèi)部狀態(tài)的信息(例如,哪個(gè)任務(wù)正在運(yùn)行,哪些任務(wù)準(zhǔn)備運(yùn)行等)。
1.1.2AUTOSAR
AUTOSAR(汽車開(kāi)放系統(tǒng)架構(gòu))是一個(gè)開(kāi)放和標(biāo)準(zhǔn)化的汽車軟件架構(gòu),由全球汽車制造商、供應(yīng)商和工具開(kāi)發(fā)人員共同開(kāi)發(fā)。
AUTOSAR為基本軟件模塊(BSW)提供規(guī)范,如操作系統(tǒng)、通信驅(qū)動(dòng)程序、內(nèi)存驅(qū)動(dòng)程序和其他微控制器抽象套件。AUTOSAR標(biāo)準(zhǔn)還定義了一個(gè)基于組件的體系結(jié)構(gòu)模型。該模型定義了虛擬功能總線(VFB),它定義了應(yīng)用軟件組件+(SW-Cs)之間通信的抽象。VFB允許sw - c獨(dú)立于底層硬件,使其在不同的ecu之間可移植,并在多個(gè)汽車項(xiàng)目中可重用。VFB抽象由AUTOSAR運(yùn)行時(shí)環(huán)境(RTE)進(jìn)行封裝。RTE提供sw - c和BSW之間的“膠水(glue)”。
AUTOSAR操作系統(tǒng)是OSEK操作系統(tǒng)規(guī)范的擴(kuò)展。AUTOSAR操作系統(tǒng)包括OSEK操作系統(tǒng)的所有特性,并添加了一些新功能,這些功能分為以下四個(gè)可伸縮性類:
可伸縮性類1(Scalability Class 1)包括OSEK OS加:
調(diào)度表(Schedule Tables)--在編程重復(fù)活動(dòng)時(shí),調(diào)度表為OSEK警報(bào)提供了一個(gè)更簡(jiǎn)單的替代方案。每個(gè)調(diào)度表都可以作為單個(gè)單元進(jìn)行管理,您可以在運(yùn)行時(shí)在表之間進(jìn)行切換,從而方便地構(gòu)建模態(tài)系統(tǒng)。
軟件計(jì)數(shù)接口(Software Counter Interface)-- 操作系統(tǒng)和計(jì)數(shù)器之間的交互已經(jīng)標(biāo)準(zhǔn)化。它在OSEK中是特定于供應(yīng)商的。
棧監(jiān)控(Stack Monitoring)-- 添加了額外的調(diào)試支持,以幫助處理堆棧錯(cuò)誤。
可伸縮類2(Scalability Class 2)包括可伸縮類1加:
調(diào)度表同步(Schedule Table Synchronization)-- 調(diào)度表可以與全局時(shí)間源同步(盡管這在可伸縮性類1中是很可能的)。
定時(shí)保護(hù)(Timing Protection)-- 添加保護(hù)是為了防止任務(wù)和中斷執(zhí)行時(shí)間過(guò)長(zhǎng)或過(guò)頻繁。保護(hù)方案允許您在運(yùn)行時(shí)約束系統(tǒng)定時(shí)的那些方面,這些方面控制您的系統(tǒng)是否滿足其最后期限。
可伸縮類3(Scalability Class 3)包括可伸縮類1加:
內(nèi)存保護(hù)(Memory Protection)-- 內(nèi)存保護(hù)允許將系統(tǒng)劃分為OS-Applications。OS-Applications可以配置為可信的,即它們運(yùn)行在通常稱為“管理模式”的模式下,或不可信的,即它們運(yùn)行在通常稱為“用戶模式”的模式下。內(nèi)存訪問(wèn)限制可以為不可信的OS-Applications編程,操作系統(tǒng)在運(yùn)行時(shí)管理目標(biāo)MCU的內(nèi)存管理功能以提供保護(hù)。還有一種受信任的保護(hù)模式,其中代碼是受信任的,但也可以有內(nèi)存訪問(wèn)限制。
服務(wù)保護(hù)(Service Protection)-- 可以允許或拒絕對(duì)OS API的訪問(wèn),以配置防護(hù)任務(wù)/ isr。
例如,你可以禁止一個(gè)操作系統(tǒng)應(yīng)用程序中的任務(wù)激活另一個(gè)操作系統(tǒng)應(yīng)用程序中的任務(wù)。API調(diào)用保護(hù)還提供了一種機(jī)制,通過(guò)添加可信函數(shù)和授予或拒絕對(duì)這些函數(shù)的訪問(wèn)來(lái)擴(kuò)展API,就像對(duì)操作系統(tǒng)API一樣。
可伸縮類4(Scalability Class 4)是可伸縮類2和可伸縮類3的超集。
RTA-OS 6.1.3支持所有AUTOSAR OS R3.x/4.x來(lái)自可伸縮性類1-4的特性。它還支持AUTOSAR多核操作系統(tǒng)規(guī)范中描述的多核應(yīng)用程序,包括IOC (OsApplication Inter Communication)機(jī)制。IOC為AUTOSAR RTE提供服務(wù),這里不再進(jìn)一步討論。后續(xù)章節(jié)將深入介紹多核應(yīng)用程序。
由于AUTOSAR OS是基于OSEK OS的,它向后兼容現(xiàn)有的基于OSEK OS的應(yīng)用程序——即為OSEK OS編寫的應(yīng)用程序?qū)⒅饕贏UTOSAR OS上運(yùn)行而無(wú)需修改。
然而,AUTOSAR OS標(biāo)準(zhǔn)還澄清了OSEK OS規(guī)范中出現(xiàn)的一些不明確之處,這些不明確之處是在OSEK OS的行為未定義或特定于供應(yīng)商時(shí)出現(xiàn)的,因?yàn)樗鼈兇砹丝梢浦残缘恼系K。
從OSEK操作系統(tǒng)遷移并依賴于OSEK操作系統(tǒng)特性的特定實(shí)現(xiàn)的用戶應(yīng)該意識(shí)到AUTOSAR OS在以下情況下定義了必需的OSEK操作系統(tǒng)行為:
參考指南提供了OSEK OS和AUTOSAR OS之間的API調(diào)用兼容性列表。
AUTOSAR OS將OSEK的OIL配置格式替換為基于xml的配置語(yǔ)言。AUTOSAR XML采用了與OIL中相同的配置對(duì)象和概念,但是使用了不同的語(yǔ)法。
1.1.3Unique RTA-OS Features
RTA-OS不僅僅是一個(gè)AUTOSAR OS。內(nèi)核設(shè)計(jì)用于支持軟件工程師構(gòu)建和集成實(shí)時(shí)系統(tǒng)。
可移植性說(shuō)明:RTA-OS特定的特性不能保證可移植到OSEK OS或AUTOSAR OS的其他實(shí)現(xiàn)中。
添加的功能特點(diǎn)包括:
時(shí)間監(jiān)控(Timing monitor),以在運(yùn)行時(shí)測(cè)量任務(wù)和第2類isr的執(zhí)行時(shí)間,并根據(jù)預(yù)先配置的預(yù)算可選擇地檢查時(shí)間。
增強(qiáng)的堆棧監(jiān)視(Enhanced Stack Monitoring)提供了額外的可能性來(lái)幫助您調(diào)試堆棧問(wèn)題。
RTA-TRACE集成(RTA-TRACE Integration)提供操作系統(tǒng)內(nèi)核的自動(dòng)檢測(cè),以支持ETAS RTA TRACE實(shí)時(shí)操作系統(tǒng)分析和可視化工具,以便您可以實(shí)時(shí)準(zhǔn)確地查看操作系統(tǒng)正在做什么。
用戶控制硬件(User control of hardware),這樣就不需要把硬件的控制,如外圍定時(shí)器、緩存和I/O端口等移交給操作系統(tǒng)。所有硬件交互都通過(guò)RTA-OS定義良好的硬件接口進(jìn)行。
可預(yù)測(cè)的運(yùn)行時(shí)開(kāi)銷(Predictable run-time overheads),如切換任務(wù)、處理中斷和喚醒任務(wù),具有較低的最差情況邊界,并且在執(zhí)行時(shí)間內(nèi)幾乎沒(méi)有可變性。
圖形脫機(jī)配置編輯器(Graphical offline configuration editor),支持操作系統(tǒng)的自動(dòng)存儲(chǔ)XML配置。
作為RTA-OS代碼生成,您可以輕松地集成到構(gòu)建過(guò)程中(Easy integration into your build process),這只需要一個(gè)可以從任何構(gòu)建環(huán)境中驅(qū)動(dòng)的命令行工具。
使用離線工具的高度可擴(kuò)展的內(nèi)核架構(gòu)(Highly scalable kernel architecture),可以自動(dòng)優(yōu)化應(yīng)用程序的內(nèi)核。
1.1.4Summary
-- RTA-OS是一種針對(duì)嵌入式系統(tǒng)的搶占式RTOS
-- 內(nèi)核提供AUTOSAR OS R3.x/4中指定的特性標(biāo)準(zhǔn)用于所有可伸縮性類,包括對(duì)遺留OSEK操作系統(tǒng)的支持。
-- RTA-OS提供了額外的功能,可以更容易地將AUTOSAR OS集成到構(gòu)建過(guò)程中。
審核編輯:劉清
-
RAM
+關(guān)注
關(guān)注
8文章
1369瀏覽量
114890 -
AUTOSAR
+關(guān)注
關(guān)注
10文章
363瀏覽量
21731 -
RTOS
+關(guān)注
關(guān)注
22文章
819瀏覽量
119823 -
VDX
+關(guān)注
關(guān)注
0文章
9瀏覽量
9788
原文標(biāo)題:符合AUTOSAR標(biāo)準(zhǔn)的RTA-OS --功能簡(jiǎn)介
文章出處:【微信號(hào):汽車電子嵌入式,微信公眾號(hào):汽車電子嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論