專利名稱:可執(zhí)行外部程序碼的集成電路和方法
技術(shù)領(lǐng)域:
本發(fā)明涉及一種集成電路及其運(yùn)作方法,尤其是涉及一種可執(zhí)行外部程序碼的集成電路和其運(yùn)作方法。
背景技術(shù):
在設(shè)計(jì)集成電路時(shí),研發(fā)人員常會(huì)使用處理器(processor)配合特定功能的電路設(shè)計(jì),以便在產(chǎn)品效能、研發(fā)時(shí)程和產(chǎn)品應(yīng)用的彈性等方面達(dá)成需求。處理器也常被稱為微處理器(microprocessor)、控制器(controller)、微控制器(micro controller)等。特定功能的電路設(shè)計(jì)因?yàn)橹恍鑸?zhí)行某些特定功能,因此效能通常較佳,但電路設(shè)計(jì)的研發(fā)需要較長(zhǎng)的時(shí)間,也較難因應(yīng)不同的產(chǎn)品應(yīng)用而更動(dòng)電路設(shè)計(jì)。處理器雖然通常效能略差,但能配合研發(fā)人員所撰寫(xiě)的軟件或固件(firmware)而能執(zhí)行較多功能,因此可縮短研發(fā)時(shí)間, 并且提供較大的彈性。當(dāng)運(yùn)作時(shí),處理器讀取于非揮發(fā)性(non-volatile)記憶體的程序碼,以執(zhí)行所需的功能。非揮發(fā)性記憶體常內(nèi)建于集成電路內(nèi),例如,以只讀記憶體(read only memory, ROM)、快閃記憶體(flash memory)等方式實(shí)現(xiàn),并且于集成電路制造時(shí)寫(xiě)入程序碼。若集成電路制造完成后,需要新增或修改程序碼以使集成電路達(dá)成所需的功能,則可能需要藉由修改只讀記憶體的內(nèi)容,并修改或重新制造光罩后,才能制造具有經(jīng)修改的程序碼的集成電路。雖然修改只讀記憶體的內(nèi)容比起修改電路設(shè)計(jì)已經(jīng)較為容易,但仍需耗費(fèi)許多資金和時(shí)間。因此,有些修改方式藉由將新增或修改過(guò)的程序碼儲(chǔ)存于另一個(gè)外部的非揮發(fā)性記憶體,當(dāng)集成電路運(yùn)作時(shí),不但會(huì)讀取內(nèi)部的非揮發(fā)性記憶體內(nèi)的程序碼,并且會(huì)讀取外部的非揮發(fā)性記憶體的程序碼。如此一來(lái),研發(fā)人員便能以較彈性且低成本的方式來(lái)新增或修改程序碼,并且上下游協(xié)力廠商的研發(fā)人員也能以這種方式輕易的新增或修改集成電路的功能,而能發(fā)展出更多應(yīng)用。此外,有些處理器支援可重復(fù)利用記憶體(data overlay或share memory)的功能,讓程序碼中的各個(gè)例程(routine)能夠共用相同的隨機(jī)記憶體(random access memory, RAM),而能夠節(jié)省所使用的隨機(jī)存取記憶體。例如,A例程需要在隨機(jī)記憶體使用 30個(gè)記憶單元存取A例程所需的數(shù)據(jù)(data或variable),B例程需要在隨機(jī)記憶體使用 20個(gè)記憶單元存取B例程所需的數(shù)據(jù),若此二例程不會(huì)同時(shí)執(zhí)行,則可讓A例程和B例程在隨機(jī)記憶體上共用部份或全部的記憶單元。例程也有被稱為子例程(sub-routine)、程序 (program)、子程序(sub-program)、流程(process)等名稱,而記憶單元可依設(shè)計(jì)考量采用位元組(byte)、字組(word)或其他合適的記憶體容量。然而,采用可重復(fù)利用記憶體功能的處理器,需要更仔細(xì)的控管各個(gè)例程的執(zhí)行和隨機(jī)存取記憶體的使用,以免例程由隨機(jī)存取記憶體中存取了錯(cuò)誤的數(shù)據(jù),而產(chǎn)生了錯(cuò)誤的輸出。例如,研發(fā)人員欲以儲(chǔ)存于外部只讀記憶體的C例程取代A例程,C例程需要在隨機(jī)記憶體上使用40個(gè)記憶體單元。假設(shè)原先A例程使用第N個(gè)至第N+四個(gè)記憶體單元存取數(shù)據(jù),而另一 D例程使用第N+30個(gè)至第N+45個(gè)記憶體單元存取數(shù)據(jù)。若直接使用C例程取代A例程,而讓C例程使用第N個(gè)至第N+39個(gè)記憶體單元存取數(shù)據(jù),則C例程和D例程都可能因此存取到錯(cuò)誤的數(shù)據(jù),而使C例程以及D例程無(wú)法執(zhí)行正確的功能。因此,如何使處理器、隨機(jī)存取記憶體、集成電路內(nèi)部和外部非揮發(fā)性記憶體正常運(yùn)作,例如,載入正確的程序碼和隨機(jī)記憶體的使用控管等,并且讓研發(fā)人員能更易于新增或修改程序碼,是長(zhǎng)期以來(lái)一直需要解決的問(wèn)題。
發(fā)明內(nèi)容
因此,需要一種執(zhí)行外部程序碼的裝置與方法以解決上述的問(wèn)題。為了解決上述問(wèn)題,本說(shuō)明書(shū)提供一種可執(zhí)行外部程序碼的集成電路,其包含有一處理器;一只讀記憶體,用以儲(chǔ)存一第一例程和一第二例程的程序碼;以及一隨機(jī)存取記憶體,具有一第一記憶體區(qū)塊和一第二記憶體區(qū)塊;其中該處理器執(zhí)行該第一例程的程序碼,并利用該第一記憶體區(qū)塊的復(fù)數(shù)個(gè)第一記憶單元存取該第一例程的一數(shù)據(jù),該處理器執(zhí)行該第二例程的程序碼,并利用該第一區(qū)塊的復(fù)數(shù)個(gè)第二記憶單元存取該第二例程的一數(shù)據(jù),該第一記憶單元與該第二記憶單元至少有一個(gè)記憶單元相同,且該處理器自一外部只讀記憶體讀取一第三例程的程序碼,并于該第二區(qū)塊存取該第三例程的一數(shù)據(jù)。本說(shuō)明書(shū)另提供一種使用一集成電路執(zhí)行外部程序碼的方法,其包含有使用一處理器執(zhí)行儲(chǔ)存于一第一只讀記憶體的一第一例程的程序碼,將該第一例程的一數(shù)據(jù)儲(chǔ)存于一隨機(jī)存取記憶體的一第一區(qū)塊的復(fù)數(shù)個(gè)第一記憶單元;使用該處理器執(zhí)行儲(chǔ)存于一第一只讀記憶體的一第二例程的程序碼,將該第二例程的一數(shù)據(jù)儲(chǔ)存于該隨機(jī)存取記憶體的該第一區(qū)塊的復(fù)數(shù)個(gè)第二記憶單元,并且該第二記憶單元的至少其中之一和該第一記憶單元的至少其中之一為相同的記憶單元;使用該處理器執(zhí)行儲(chǔ)存于一第二只讀記憶體的一第三例程的程序碼,將該第三例程的一數(shù)據(jù)儲(chǔ)存于該隨機(jī)存取記憶體的該第二區(qū)塊;其中該處理器、該第一只讀記憶體和該隨機(jī)存取記憶體設(shè)置于該集成電路內(nèi)部,而該第二只讀記憶體設(shè)置于該集成電路外部。上述實(shí)施例的優(yōu)點(diǎn)之一在于能使集成電路的研發(fā)更有彈性,并且降低所需的研發(fā)成本和時(shí)間。
170180220、240、260
導(dǎo)線
非揮發(fā)性記憶體記憶體區(qū)塊
具體實(shí)施例方式以下將配合相關(guān)圖式來(lái)說(shuō)明本發(fā)明的實(shí)施例。在這些圖式中,相同的標(biāo)號(hào)表示相同或類似的元件或流程步驟。在說(shuō)明書(shū)及后續(xù)的權(quán)利要求當(dāng)中使用了某些詞匯來(lái)指稱特定的元件。本領(lǐng)域技術(shù)人員應(yīng)可理解,可能會(huì)有不同的名詞用來(lái)稱呼同樣的元件。本說(shuō)明書(shū)及后續(xù)的權(quán)利要求并不以名稱的差異作為區(qū)分元件的方式,而是以元件在功能上的差異作為區(qū)分的基準(zhǔn)。在通篇說(shuō)明書(shū)及后續(xù)的權(quán)項(xiàng)當(dāng)中所提及的「包含」為一開(kāi)放式的用語(yǔ),故應(yīng)解釋成「包含但不限定于...」。另外,「耦接」一詞包含任何直接及間接的連接手段。因此, 若文中描述第一裝置耦接于第二裝置,則代表第一裝置可直接連接(包含通過(guò)電性連接、 有線/無(wú)線傳輸、或光學(xué)傳輸?shù)扔嵦?hào)連接方式)于第二裝置,或通過(guò)其他裝置或連接手段間接的電性或訊號(hào)連接至該第二裝置。圖1為本發(fā)明一實(shí)施例的集成電路系統(tǒng)100簡(jiǎn)化后的功能方塊圖。集成電路系統(tǒng) 100包含集成電路110、導(dǎo)線170和非揮發(fā)性記憶體180。集成電路100包含處理器120、非揮發(fā)性記憶體130和隨機(jī)存取記憶體140。處理器120可以采用任何合適形式的處理器,例如,精簡(jiǎn)指令集(reduced instruction set computing, RISC)處理器、復(fù)雜指令集(complex instruction set computing, CISC)處理器或其他架構(gòu)的處理器,并且具有可重復(fù)利用記憶體的功能。例如,處理器120可使用 M8051系列處理器或80390系列處理器。非揮發(fā)性記憶體130可以采用快閃記憶體、可抹寫(xiě)式(erasable)的只讀記憶體或不可抹寫(xiě)式的只讀記憶體等,用以儲(chǔ)存處理器120可執(zhí)行的程序碼。該程序碼可以是各種程序語(yǔ)言的原始碼(source code)、匯編碼(assembly code)或可執(zhí)行碼等。隨機(jī)存取記憶體140可以采用靜態(tài)隨機(jī)存取記憶體(static RAM, SRAM)、動(dòng)態(tài)隨機(jī)存取記憶體(dynamic RAM, DRAM)或其他形式的隨機(jī)存取記憶體。處理器120執(zhí)行各個(gè)例程時(shí),會(huì)使用隨機(jī)存取記憶體140以存取所需的數(shù)據(jù)。非揮發(fā)性記憶體180可以采用快閃記憶體、可抹寫(xiě)式的只讀記憶體、不可抹寫(xiě)式的只讀記憶體、另一個(gè)集成電路中的非揮發(fā)性記憶體、或任何合適的非揮發(fā)性記憶裝置。集成電路110和非揮發(fā)性記憶體180可設(shè)置于同一電路板(圖中未示),或者分別設(shè)置于不同的電路板(圖中未示)。相較于設(shè)置于集成電路110內(nèi)部的非揮發(fā)性記憶體130,非揮發(fā)性記憶體180為設(shè)置于集成電路110外部的元件,并且能以各種方式實(shí)現(xiàn)。例如,集成電路110和非揮發(fā)性記憶體180可分別為經(jīng)封裝的晶片,或者也可以用系統(tǒng)級(jí)封裝(system in package, SIP)等方式,將集成電路110和非揮發(fā)性記憶體180的未封裝芯片(die)封裝為單一晶片。集成電路110制造完成后,可將欲新增或修改的程序碼儲(chǔ)存于外部的非揮發(fā)性記憶體180,而可避免修改集成電路110的非揮發(fā)性記憶體130。因此,處理器120可執(zhí)行非揮發(fā)性記憶體130的程序碼,并且配合非揮發(fā)性記憶體180的程序碼,而能新增、減少、更新或修改集成電路110的功能。
集成電路110和非揮發(fā)性記憶體180間以導(dǎo)線170相耦接,并采用自訂或標(biāo)準(zhǔn)的協(xié)議傳輸信號(hào)。圖ι中僅繪制一條導(dǎo)線170示意,實(shí)作上,導(dǎo)線170可為一條或多條的導(dǎo)線, 以于集成電路110和非揮發(fā)性記憶體180間傳輸信號(hào)。圖2為圖1中隨機(jī)存取記憶體140的記憶體區(qū)塊劃分的一實(shí)施例示意圖。隨機(jī)存取記憶體140包含有記憶體區(qū)塊220、240和沈0。圖2中記憶體區(qū)塊的位置和數(shù)目?jī)H為示意,并非用以表示記憶體區(qū)塊在隨機(jī)存取記憶體140內(nèi)的物理位置及數(shù)量。處理器120可藉由分頁(yè)(PAGED)或是其他記憶體存取機(jī)制,能而對(duì)記憶體區(qū)塊快速的存取,并且可能有數(shù)種不同的存取速度。因此,記憶體區(qū)塊220、240和260可以分別是處理器120可以快速存取的記憶體區(qū)塊,或處理器120存取較慢的記憶體區(qū)塊。例如,80390 系列處理器中,BDATA、IDATA和PDATA等記憶體區(qū)塊為處理器可快速存取的記憶體區(qū)塊,相較而言,處理器存取XDATA等記憶體區(qū)塊的速度則較慢。以下將以圖3和圖4搭配圖1和圖2來(lái)進(jìn)一步說(shuō)明集成電路系統(tǒng)100的運(yùn)作方式。 圖3為本發(fā)明使用集成電路110執(zhí)行外部程序碼的方法的一實(shí)施例的流程圖300,在此實(shí)施例中,集成電路系統(tǒng)100僅執(zhí)行儲(chǔ)存于非揮發(fā)性記憶體130內(nèi)的程序碼。在流程310中,處理器120執(zhí)行儲(chǔ)存于非揮發(fā)性記憶體130的A例程的程序碼,并使用記憶體區(qū)塊220存取A例程所需的數(shù)據(jù)。在流程320中,處理器120執(zhí)行儲(chǔ)存于非揮發(fā)性記憶體130的B例程的程序碼,并使用記憶體區(qū)塊220存取B例程所需的數(shù)據(jù)。在此實(shí)施例中,處理器120不會(huì)同時(shí)執(zhí)行A 例程和B例程,因此A例程和B例程在記憶體區(qū)塊220中共用了部份或全部的記憶體單元。在流程330中,處理器120執(zhí)行儲(chǔ)存于非揮發(fā)性記憶體130的C例程的程序碼,并使用記憶體區(qū)塊220存取C例程所需的數(shù)據(jù)。C例程設(shè)置為可被非揮發(fā)性記憶體180的程序碼所取代,此外,也可依據(jù)所需的記憶體單元大小和存取速度等條件,設(shè)置為讓C例程使用記憶體區(qū)塊240或260存取C例程所需的數(shù)據(jù)。在圖3的實(shí)施例中,也可依照不同的設(shè)計(jì)考量,將A例程和B例程設(shè)置為使用記憶體區(qū)塊240或260存取所需的數(shù)據(jù)。而記憶體區(qū)塊220、240或沈0,分別可以是處理器120 可以快速存取的記憶體區(qū)塊,或處理器120存取較慢的記憶體區(qū)塊。圖4為本發(fā)明使用集成電路110執(zhí)行外部程序碼的方法的另一實(shí)施例的流程圖 400,與圖3的實(shí)施例類似,但在此實(shí)施例中,處理器120使用非揮發(fā)性記憶體180的程序碼取代部份非揮發(fā)性記憶體130的程序碼。在流程410中,處理器120執(zhí)行儲(chǔ)存于非揮發(fā)性記憶體130的A例程的程序碼,并使用記憶體區(qū)塊220存取A例程所需的數(shù)據(jù)。在流程420中,處理器120執(zhí)行儲(chǔ)存于非揮發(fā)性記憶體130的B例程的程序碼,并使用記憶體區(qū)塊220存取B例程所需的數(shù)據(jù)。在此實(shí)施例中,處理器120不會(huì)同時(shí)執(zhí)行A 例程和B例程,因此A例程和B例程在記憶體區(qū)塊220中共用了部份或全部的記憶體單元。在流程430中,處理器120執(zhí)行儲(chǔ)存于非揮發(fā)性記憶體180的D例程的程序碼,用以代替非揮發(fā)性記憶體130的C例程。此時(shí),選用非C例程所使用的記憶體區(qū)塊作為存取D 例程所需數(shù)據(jù)的記憶體區(qū)塊,如此就可避免因C例程和D例程所使用的記憶體區(qū)塊的大小不同而產(chǎn)生的數(shù)據(jù)存取錯(cuò)誤。例如,圖3的C例程使用記憶體區(qū)塊220存取所需的數(shù)據(jù),故處理器120在流程430中可選用記憶體區(qū)塊240或260作為存取D例程所需數(shù)據(jù)的記憶體
7區(qū)塊。在一些實(shí)施例中,D例程僅于記憶體區(qū)塊中儲(chǔ)存區(qū)域數(shù)據(jù)(local data或local variable) 0區(qū)域數(shù)據(jù)一詞在此是指僅于D例程中為有效的數(shù)據(jù)。在另一些實(shí)施例中,D例程可于記憶體區(qū)塊中存取全域數(shù)據(jù)(glcAal data或global variable),全域數(shù)據(jù)即在D例程和其他例程中皆為有效的數(shù)據(jù)。一般情況下,全域數(shù)據(jù)沒(méi)有初始值,而是由處理器120自其他記憶體區(qū)塊中將部分?jǐn)?shù)值復(fù)制過(guò)來(lái)做為全域數(shù)據(jù)的初始值。例如,以上述的80390處理器而言,可設(shè)置C例程使用DATA、BDATA或IDATA記憶體區(qū)塊存取區(qū)域數(shù)據(jù),而將D例程設(shè)置為使用PDATA及/或XDATA記憶體區(qū)塊存取區(qū)域數(shù)據(jù)。在另一些實(shí)施例中,可將D例程設(shè)置為使用XDATA記憶體區(qū)塊存取全域數(shù)據(jù),且全域數(shù)據(jù)不設(shè)置初始值,而是由處理器120自其他記憶體區(qū)塊中將某些數(shù)值復(fù)制過(guò)來(lái)做為全域數(shù)據(jù)的初始值。在一些實(shí)施例中,D例程和其他儲(chǔ)存于非揮發(fā)性記憶體180的例程會(huì)呼叫非揮發(fā)性記憶體130的E例程,若E例程會(huì)因?yàn)镈例程或其他例程而改變?cè)谟洃涹w區(qū)塊中所存取的記憶體單元,將會(huì)使E例程產(chǎn)生錯(cuò)誤。因此,可使用函數(shù)或位移等方式,使E例程執(zhí)行或被其他例程呼叫時(shí),使用記憶體區(qū)塊中固定的記憶體單元來(lái)存取所需的數(shù)據(jù)。以上所述僅為本發(fā)明的較佳實(shí)施例,凡依本發(fā)明權(quán)利要求所做的均等變化與修飾,皆應(yīng)屬本發(fā)明的涵蓋范圍。
權(quán)利要求
1.一種可執(zhí)行外部程序碼的集成電路,其包含有一處理器;一只讀記憶體,用以儲(chǔ)存一第一例程和一第二例程的程序碼;以及一隨機(jī)存取記憶體,具有一第一記憶體區(qū)塊和一第二記憶體區(qū)塊;其中該處理器執(zhí)行該第一例程的程序碼,并利用該第一記憶體區(qū)塊的復(fù)數(shù)個(gè)第一記憶單元存取該第一例程的一數(shù)據(jù),該處理器執(zhí)行該第二例程的程序碼,并利用該第一區(qū)塊的復(fù)數(shù)個(gè)第二記憶單元存取該第二例程的一數(shù)據(jù),該第一記憶單元與該第二記憶單元至少有一個(gè)記憶單元相同,且該處理器自一外部只讀記憶體讀取一第三例程的程序碼,并于該第二區(qū)塊存取該第三例程的一數(shù)據(jù)。
2.如權(quán)利要求1所述的集成電路,其中該處理器存取該第一記憶體區(qū)塊的時(shí)間少于或等于存取該第二記憶體區(qū)塊的時(shí)間。
3.如權(quán)利要求2所述的集成電路,其中該處理器僅于該第二區(qū)塊存取該第三例程的一區(qū)域數(shù)據(jù)。
4.如權(quán)利要求2所述的集成電路,其中該處理器僅于該第二區(qū)塊存取該第三例程的一全域數(shù)據(jù),且該處理器自該第一區(qū)塊或一第三區(qū)塊復(fù)制一數(shù)值作為該全域數(shù)據(jù)的初始值。
5.如權(quán)利要求1所述的集成電路,其中該處理器存取該第二記憶體區(qū)塊的時(shí)間少于存取該第一記憶體區(qū)塊的時(shí)間。
6.如權(quán)利要求5所述的集成電路,其中該處理器僅于該第二區(qū)塊存取該第三例程的一區(qū)域數(shù)據(jù)。
7.如權(quán)利要求1所述的集成電路,其中該第三例程另呼叫一第四例程,該第四例程使用該隨機(jī)存取記憶體的復(fù)數(shù)個(gè)固定的記憶體單元存取數(shù)據(jù)。
8.一種使用一集成電路執(zhí)行外部程序碼的方法,其包含有使用一處理器執(zhí)行儲(chǔ)存于一第一只讀記憶體的一第一例程的程序碼,將該第一例程的一數(shù)據(jù)儲(chǔ)存于一隨機(jī)存取記憶體的一第一區(qū)塊的復(fù)數(shù)個(gè)第一記憶單元;使用該處理器執(zhí)行儲(chǔ)存于該第一只讀記憶體的一第二例程的程序碼,將該第二例程的一數(shù)據(jù)儲(chǔ)存于該隨機(jī)存取記憶體的該第一區(qū)塊的復(fù)數(shù)個(gè)第二記憶單元,并且該第二記憶單元的至少其中之一和該第一記憶單元的至少其中之一為相同的記憶單元;使用該處理器執(zhí)行儲(chǔ)存于一第二只讀記憶體的一第三例程的程序碼,將該第三例程的一數(shù)據(jù)儲(chǔ)存于該隨機(jī)存取記憶體的該第二區(qū)塊;其中該處理器、該第一只讀記憶體和該隨機(jī)存取記憶體設(shè)置于該集成電路內(nèi)部,而該第二只讀記憶體設(shè)置于該集成電路外部。
9.如權(quán)利要求8所述的方法,其中該處理器存取該第一記憶體區(qū)塊的時(shí)間少于或等于存取該第二記憶體區(qū)塊的時(shí)間。
10.如權(quán)利要求9所述的方法,其中該處理器僅于該第二區(qū)塊存取該第三例程的一區(qū)域數(shù)據(jù)。
11.如權(quán)利要求9所述的方法,其中該處理器僅于該第二區(qū)塊存取該第三例程的一全域數(shù)據(jù),且該處理器自該第一區(qū)塊或一第三區(qū)塊復(fù)制一數(shù)值作為該全域數(shù)據(jù)的初始值。
12.如權(quán)利要求8所述的方法,其中該處理器存取該第二記憶體區(qū)塊的時(shí)間少于存取該第一記憶體區(qū)塊的時(shí)間。
13.如權(quán)利要求12所述的方法,其中該處理器僅于該第二區(qū)塊存取該第三例程的一區(qū)域數(shù)據(jù)。
14.如權(quán)利要求8所述的方法,其中該第三例程另呼叫一第四例程,該第四例程使用該隨機(jī)存取記憶體的復(fù)數(shù)個(gè)固定的記憶體單元存取數(shù)據(jù)。
全文摘要
本發(fā)明提出一種可執(zhí)行外部程序碼的集成電路,其包含有一處理器;一只讀記憶體,用以儲(chǔ)存第一例程和第二例程的程序碼;以及一隨機(jī)存取記憶體,具有第一記憶體區(qū)塊和第二記憶體區(qū)塊。處理器執(zhí)行第一例程的程序碼,并利用第一記憶體區(qū)塊的復(fù)數(shù)個(gè)第一記憶單元存取第一例程的數(shù)據(jù)。處理器執(zhí)行第二例程的程序碼,并利用第一區(qū)塊的復(fù)數(shù)個(gè)第二記憶單元存取第二例程的數(shù)據(jù),第一記憶單元與第二記憶單元至少有一個(gè)記憶單元相同。處理器執(zhí)行外部只讀記憶體的第三例程的程序碼,并于第二區(qū)塊存取第三例程的數(shù)據(jù)。本發(fā)明還提出一種使用該集成電路執(zhí)行外部程序碼的方法。
文檔編號(hào)G06F9/34GK102385503SQ20101027231
公開(kāi)日2012年3月21日 申請(qǐng)日期2010年9月1日 優(yōu)先權(quán)日2010年9月1日
發(fā)明者林政良 申請(qǐng)人:絡(luò)達(dá)科技股份有限公司