www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀] 最近在調(diào)優(yōu)龍ST2410的板子,總體來說,優(yōu)龍的板子做的不錯(cuò),技術(shù)支持也還可以~不過呢,優(yōu)龍?zhí)峁┑腤inCE BSP也只是在三星的公版BSP上少量修改而成的,雖然三星S3C2410能夠

 最近在調(diào)優(yōu)龍ST2410的板子,總體來說,優(yōu)龍的板子做的不錯(cuò),技術(shù)支持也還可以~

不過呢,優(yōu)龍?zhí)峁┑腤inCE BSP也只是在三星的公版BSP上少量修改而成的,雖然三星S3C2410能夠提供3個(gè)UART支持,也就是說每個(gè)UART控制器都可以工作在Interrupt(中斷)模式或DMA(直接內(nèi)存訪問)模式,但是三星提供的公版BSP上只添加了UART0(COM1)和UART2(紅外)的支持,所以優(yōu)龍?zhí)峁┑腂SP也就只有一個(gè)串口能用,另外一個(gè)紅外我也不知道怎么用(沒有紅外設(shè)備測試)。

這樣的話,我買的板子上面的兩個(gè)串口豈不是浪費(fèi)了一個(gè),這可不行,因?yàn)镃OM1是默認(rèn)作為調(diào)試串口了,系統(tǒng)的啟動信息都是靠這個(gè)串口輸出的,總不能調(diào)試和使用共用一個(gè)吧!

在優(yōu)龍官方論壇尋覓未果,他們好像就沒做UART1的BSP支持,這樣,只好自己動手,豐衣足食了。

我的平臺是WinCE 5.0和Platform Builder 5.0,雖然手頭的資料都是WinCE 4.2的,但根據(jù)修改比較,好像沒有區(qū)別,不知道WinCE 5.0到底升級了什么?

首先列舉一下要修改文件的清單:

SMDK2410FILESplatform.reg

SMDK2410INCoalintr.h

SMDK2410DRIVERSSERIALser2410_hw.c

SMDK2410DRIVERSSERIALser2410_ser.c

SMDK2410KERNELHALcfw.c

SMDK2410KERNELHALARMarmint.c

SMDK2410smdk2410.cec

好了,Let's gooooooooo~

1、打開platform.reg文件,這個(gè)是WinCE注冊表文件,在這里,我們要修改并添加串口。

搜索:[HKEY_LOCAL_MACHINEDriversBuiltInSER2410],這就是串口1。

將其下面的鍵值改為:

[HKEY_LOCAL_MACHINEDriversBuiltInSER2410]

"DeviceArrayIndex"=dword:0

"Irq"=dword:13

"IoBase"=dword:50000000

"IoLen"=dword:2C

"Prefix"="COM"

"Dll"="SER2410.Dll"

"Order"=dword:0

"Priority"=dword:0

"Port"="COM1:"

"DeviceType"=dword:0

"FriendlyName"="Serial Cable on COM1:"

"Tsp"="Unimodem.dll"

"DevConfig"=hex: 10,00, 00,00, 05,00,00,00, 10,01,00,00, 00,4B,00,00, 00,00, 08, 00, 00, 00,00,00,00

再在其后面添加串口2:

[HKEY_LOCAL_MACHINEDriversBuiltInSER2410_2]

"DeviceArrayIndex"=dword:1

"Irq"=dword:23

"IoBase"=dword:50004000

"IoLen"=dword:2C

"Prefix"="COM"

"Dll"="SER2410.Dll"

"Order"=dword:1

"Priority"=dword:0

"Port"="COM2:"

"DeviceType"=dword:0

"FriendlyName"="Serial Cable on COM2:"

"Tsp"="Unimodem.dll"

"DevConfig"=hex: 10,00, 00,00, 05,00,00,00, 10,01,00,00, 00,4B,00,00, 00,00, 08, 00, 00, 00,00,00,00

[HKEY_LOCAL_MACHINEDriversBuiltInSER2410_2Unimodem]

"Tsp"="Unimodem.dll"

"DeviceType"=dword:0

"FriendlyName"="SER2410_2 UNIMODEM"

"DevConfig"=hex: 10,00, 00,00, 05,00,00,00, 10,01,00,00, 00,4B,00,00, 00,00, 08, 00, 00, 00,00,00,00

再搜索:[HKEY_LOCAL_MACHINEDriversBuiltInIRDA2410],這個(gè)是紅外,也要修改下:

[HKEY_LOCAL_MACHINEDriversBuiltInIRDA2410]

"DeviceArrayIndex"=dword:2

"Irq"=dword:19

"IoBase"=dword:50008000

"IoLen"=dword:2C

"Prefix"="COM"

"Dll"="IRDA2410.Dll"

"Order"=dword:0

"Priority"=dword:0

"Port"="COM3:"

"DeviceType"=dword:0 ; IRDA modem, 0 -> null modem

"FriendlyName"="S2410 IRDA2410"

"Index"=dword:2

"IClass"="{A32942B7-920C-486b-B0E6-92A702A99B35}"

好了,注冊表就改到這里,以上要特別注意Irq的值,要和oalintr.h里面的中斷定義對應(yīng),并且注意Order的順序,DeviceArrayIndex的值以及IoBase,后面串口源代碼中要用到該值作判斷。

2、打開oalintr.h文件,我們添加一個(gè)新的串口,并定義中斷號。

添加:

#define SYSINTR_SERIAL1 (SYSINTR_FIRMWARE+19)

這里,我們可以看到SYSINTR_SERIAL1定義到16+19=35=0x23,與注冊表中一致。

然后修改下這個(gè)地方:

MapIrq2SysIntr(DWORD _Irq)

{

if( _Irq<=19 )

return ( SYSINTR_FIRMWARE + _Irq );

else

return (0xffffffff);

}

3、打開串口源文件中ser2410_hw.c文件。

搜索:

S2410_SetSerialIOP(

PVOID pHead // @parm points to device head

)

將其函數(shù)改為:

{

PS2410_UART_INFO pHWHead = (PS2410_UART_INFO)pHead;

PSER_INFO pHWHead1 = (PSER_INFO)pHead;

RETAILMSG(DEBUGMODE, (TEXT("S2410_SetSerialIOP ")));

if(pHWHead1->dwIOBase == 0x50004000)

{

#if USEVIRTUAL

EnterCriticalSection(&(pHWHead->RegCritSec));

v_pIOPregs->rGPHCON &= ~(0x3<<8 | 0x3<<10 /*| 0x3<<12 | 0x3<<14*/); // clear uart 1 - rx, tx[!--empirenews.page--]

v_pIOPregs->rGPHCON |= (0x2<<8 | 0x2<<10 /*| 0x1<<12 | 0x0<<14*/);

v_pIOPregs->rGPHCON |= (0x2<<0 | 0x2<<2 );

v_pIOPregs->rGPHUP |= 0x03;

pHWHead->rDTRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);

pHWHead->rDSRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);

pHWHead->DtrPortNum = 0;

pHWHead->DsrPortNum = 1;

#else

volatile IOPreg *s2410IOP;

s2410IOP = (volatile IOPreg *)IOP_BASE;

EnterCriticalSection(&(pHWHead->RegCritSec));

s2410IOP->rGPHCON &= ~(0x3<<8 | 0x3<<10/* | 0x3<<12 | 0x3<<14*/); // clear uart 1 - rx, tx

s2410IOP->rGPHCON |= (0x2<<8 | 0x2<<10 /*| 0x1<<12 | 0x0<<14*/);

s2410IOP->rGPHCON |= (0x2<<0 | 0x2<<2 );

s2410IOP->rGPHUP |= 0x03;

pHWHead->rDTRport = (volatile unsigned int *)(IOP_BASE+0x74); //s2410IOP->rGPHDAT

pHWHead->rDSRport = (volatile unsigned int *)(IOP_BASE+0x74);

pHWHead->DtrPortNum = 0;

pHWHead->DsrPortNum = 1;

#endif

}

else if(pHWHead1->dwIOBase == 0x50008000)

{

#if USEVIRTUAL

EnterCriticalSection(&(pHWHead->RegCritSec));

v_pIOPregs->rGPHCON &= ~( 0x3<<12 | 0x3<<14); // clear uart 2 - rx, tx

v_pIOPregs->rGPHCON |= ( 0x2<<12 | 0x2<<14);

v_pIOPregs->rGPHCON |= (0x2<<0 | 0x2<<2 );

v_pIOPregs->rGPHUP &= ~0xc0;

pHWHead->rDTRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);

pHWHead->rDSRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);

pHWHead->DtrPortNum = 0;

pHWHead->DsrPortNum = 1;

#else

volatile IOPreg *s2410IOP;

s2410IOP = (volatile IOPreg *)IOP_BASE;

EnterCriticalSection(&(pHWHead->RegCritSec));

s2410IOP->rGPHCON &= ~(0x3<<12 | 0x3<<14); // clear uart 2 - rx, tx

s2410IOP->rGPHCON |= ( 0x02<<12 | 0x02<<14);

s2410IOP->rGPHCON |= (0x2<<0 | 0x2<<2 );

s2410IOP->rGPHUP &= ~0xc0;

pHWHead->rDTRport = (volatile unsigned int *)(IOP_BASE+0x74); //s2410IOP->rGPHDAT

pHWHead->rDSRport = (volatile unsigned int *)(IOP_BASE+0x74);

pHWHead->DtrPortNum = 0;

pHWHead->DsrPortNum = 1;

#endif

}

else

{

#if USEVIRTUAL

EnterCriticalSection(&(pHWHead->RegCritSec));

v_pIOPregs->rGPHCON &= ~(0x3<<0 | 0x3<<2 | 0x3<<4 | 0x3<<6/* | 0x3<<12 | 0x3<<14*/); // clear uart 0 - rx, tx

v_pIOPregs->rGPHCON |= (0x2<<4 | 0x2<<6/* | 0x1<<12 | 0x0<<14*/);

v_pIOPregs->rGPHCON |= (0x2<<0 | 0x2<<2 );

v_pIOPregs->rGPHUP |= 0x03;

pHWHead->rDTRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);

pHWHead->rDSRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);

pHWHead->DtrPortNum = 0;

pHWHead->DsrPortNum = 1;

#else

volatile IOPreg *s2410IOP;

s2410IOP = (volatile IOPreg *)IOP_BASE;

EnterCriticalSection(&(pHWHead->RegCritSec));

s2410IOP->rGPHCON &= ~(0x3<<0 | 0x3<<2 | 0x3<<4 | 0x3<<6 /*| 0x3<<12 | 0x3<<14*/); // clear uart 0 - rx, tx

s2410IOP->rGPHCON |= (0x2<<4 | 0x2<<6 /*| 0x1<<12 | 0x0<<14*/);

s2410IOP->rGPHCON |= (0x2<<0 | 0x2<<2 );

s2410IOP->rGPHUP |= 0x03;

pHWHead->rDTRport = (volatile unsigned int *)(IOP_BASE+0x74); //s2410IOP->rGPHDAT

pHWHead->rDSRport = (volatile unsigned int *)(IOP_BASE+0x74);

pHWHead->DtrPortNum = 0;

pHWHead->DsrPortNum =1;

#endif

}

LeaveCriticalSection(&(pHWHead->RegCritSec));

}

接著搜索:

SL_Init(

PVOID pHead, // @parm points to device head

PUCHAR pRegBase, // Pointer to 16550 register base

UINT8 RegStride, // Stride amongst the 16550 registers

EVENT_FUNC EventCallback, // This callback exists in MDD

PVOID pMddHead, // This is the first parm to callback

PLOOKUP_TBL pBaudTable // BaudRate Table

)

在PS2410_UART_INFO pHWHead = (PS2410_UART_INFO)pHead;這一句后面添加:

PSER_INFO pHWHead1 = (PSER_INFO)pHead;

再搜索:

if ( pHWHead->UseIrDA )

{

pHWHead->bINT = BIT_UART2;

pHWHead->bTxINT = INTSUB_TXD2;

pHWHead->bRxINT = INTSUB_RXD2;

pHWHead->bErrINT = INTSUB_ERR2;

#if USEVIRTUAL

pHWHead->s2410SerReg = (S2410_UART_REG *)v_pUART2regs;

[!--empirenews.page--]

pRegBase = (PUCHAR)pHWHead->s2410SerReg;

#else

pRegBase = (PUCHAR)UART2_BASE;

pHWHead->s2410SerReg = (S2410_UART_REG *)pRegBase;

#endif

}

else

{

把這其中的代碼修改為以下代碼

}

if(pHWHead1->dwIOBase == 0x50004000)

{

pHWHead->bINT = BIT_UART1;

pHWHead->bTxINT = INTSUB_TXD1;

pHWHead->bRxINT = INTSUB_RXD1;

pHWHead->bErrINT = INTSUB_ERR1;

#if USEVIRTUAL

pHWHead->s2410SerReg = (S2410_UART_REG *)v_pUART1regs;

pRegBase = (PUCHAR)pHWHead->s2410SerReg;

#else

pRegBase = (PUCHAR)UART1_BASE;

pHWHead->s2410SerReg = (S2410_UART_REG *)pRegBase;

#endif

}

else if(pHWHead1->dwIOBase == 0x50008000)

{

pHWHead->bINT = BIT_UART2;

pHWHead->bTxINT = INTSUB_TXD2;

pHWHead->bRxINT = INTSUB_RXD2;

pHWHead->bErrINT = INTSUB_ERR2;

#if USEVIRTUAL

pHWHead->s2410SerReg = (S2410_UART_REG *)v_pUART2regs;

pRegBase = (PUCHAR)pHWHead->s2410SerReg;

#else

pRegBase = (PUCHAR)UART2_BASE;

pHWHead->s2410SerReg = (S2410_UART_REG *)pRegBase;

#endif

}

else

{

pHWHead->bINT = BIT_UART0;

pHWHead->bTxINT = INTSUB_TXD0;

pHWHead->bRxINT = INTSUB_RXD0;

pHWHead->bErrINT = INTSUB_ERR0;

#if USEVIRTUAL

pHWHead->s2410SerReg = (S2410_UART_REG *)v_pUART0regs;

pRegBase = (PUCHAR)pHWHead->s2410SerReg;

#else

pRegBase = (PUCHAR)UART0_BASE;

pHWHead->s2410SerReg = (S2410_UART_REG *)pRegBase;

#endif

}

再搜索:

if ( pHWHead->UseIrDA )

{

pHWHead->pUFTXH = (volatile unsigned char *)&(v_pUART2regs->rUTXH);

pHWHead->pUFRXH = (volatile unsigned char *)&(v_pUART2regs->rURXH);

}

else

{

把這其中的代碼修改為以下代碼

}

if(pHWHead1->dwIOBase == 0x50004000)

{

pHWHead->pUFTXH = (volatile unsigned char *)&(v_pUART1regs->rUTXH);

pHWHead->pUFRXH = (volatile unsigned char *)&(v_pUART1regs->rURXH);

}

else if(pHWHead1->dwIOBase == 0x50008000)

{

pHWHead->pUFTXH = (volatile unsigned char *)&(v_pUART2regs->rUTXH);

pHWHead->pUFRXH = (volatile unsigned char *)&(v_pUART2regs->rURXH);

}

else

{

pHWHead->pUFTXH = (volatile unsigned char *)&(v_pUART0regs->rUTXH);

pHWHead->pUFRXH = (volatile unsigned char *)&(v_pUART0regs->rURXH);

}

4、打開ser2410_ser.c文件。

搜索:

const HWOBJ IoObj = {

THREAD_AT_INIT,

SYSINTR_SERIAL,

(PHW_VTBL) &IoVTbl

};

在其后面添加:

const HWOBJ Io1Obj = {

THREAD_AT_INIT,

SYSINTR_SERIAL1,

(PHW_VTBL) &IoVTbl

};

const HWOBJ Io2Obj = {

THREAD_AT_INIT,

SYSINTR_IR,

(PHW_VTBL) &IoVTbl

};

接著搜索:

const PCHWOBJ HWObjects[] = {

&IoObj,

&IrObj

};

將其修改為:

const PCHWOBJ HWObjects[] = {

&IoObj,

&Io1Obj,

&Io2Obj

};

再搜索:

GetSerialObject(

DWORD DeviceArrayIndex

)

將其函數(shù)改為:

{

PHWOBJ pSerObj;

DEBUGMSG(DEBUGMODE,(TEXT("GetSerialObject : DeviceArrayIndex = %d "), DeviceArrayIndex));

// Now return this structure to the MDD.

if ( DeviceArrayIndex == 2 )

{

RETAILMSG(1,(TEXT("GetSerialObject Io2Obj ")));

pSerObj = (PHWOBJ)(&Io2Obj);

}

else if(DeviceArrayIndex == 1)

pSerObj = (PHWOBJ)(&Io1Obj);

else

pSerObj = (PHWOBJ)(&IoObj);

return (pSerObj);

}

5、打開cfw.c文件,這就是中斷處理。

搜索:

BOOL

OEMInterruptEnable(DWORD idInt, // @parm Interrupt ID to be enabled. See for a list of possble values.

LPVOID pvData, // @parm ptr to data passed in in the call

DWORD cbData) // @parm Size of data pointed to be

 

找到這一句:case SYSINTR_SERIAL:

在其后面添加:

case SYSINTR_SERIAL1: // Serial port1.

s2410INT->rSUBSRCPND = (INTSUB_RXD1 | INTSUB_TXD1 | INTSUB_ERR1);

s2410INT->rINTSUBMSK &= ~INTSUB_RXD1;

s2410INT->rINTSUBMSK &= ~INTSUB_TXD1;

s2410INT->rINTSUBMSK &= ~INTSUB_ERR1;

s2410INT->rSRCPND = BIT_UART1;

// S3C2410X Developer Notice (page 4) warns against writing a 1 to a 0 bit in the INTPND register.

if (s2410INT->rINTPND & BIT_UART1) s2410INT->rINTPND = BIT_UART1;[!--empirenews.page--]

s2410INT->rINTMSK &= ~BIT_UART1;

break;

搜索:

void

OEMInterruptDisable(DWORD idInt) // @parm Interrupt ID to be disabled. See

還是這一句:case SYSINTR_SERIAL:

在其后面添加:

case SYSINTR_SERIAL1:

s2410INT->rINTMSK |= BIT_UART1;

s2410INT->rINTSUBMSK |= INTSUB_RXD1;

s2410INT->rINTSUBMSK |= INTSUB_TXD1;

s2410INT->rINTSUBMSK |= INTSUB_ERR1;

break;

搜索:

void

OEMInterruptDone(DWORD idInt) // @parm Interrupt ID. See

依舊找到case SYSINTR_SERIAL:

在其后面添加:

case SYSINTR_SERIAL1:

s2410INT->rINTMSK &= ~BIT_UART1;

s2410INT->rINTSUBMSK &= ~INTSUB_RXD1;

break;

6、打開armint.c文件。

搜索:else if(IntPendVal == INTSRC_UART0)

在其后面添加:

else if(IntPendVal == INTSRC_UART1)

{

SubIntPendVal = s2410INT->rSUBSRCPND;

// Note that we only mask the sub source interrupt - the serial driver will clear the

// sub source pending register.

//

if(SubIntPendVal & INTSUB_ERR1)

{

s2410INT->rINTSUBMSK |= INTSUB_ERR1;

}

else if(SubIntPendVal & INTSUB_RXD1)

{

s2410INT->rINTSUBMSK |= INTSUB_RXD1;

}

else if(SubIntPendVal & INTSUB_TXD1)

{

s2410INT->rINTSUBMSK |= INTSUB_TXD1;

}

else

{

return(SYSINTR_NOP);

}

// NOTE: Don't clear INTSRC:UART1 here - serial driver does that.

//

s2410INT->rINTMSK |= BIT_UART1;

if (s2410INT->rINTPND & BIT_UART1) s2410INT->rINTPND = BIT_UART1;

return(SYSINTR_SERIAL1);

}

7、打開smdk2410.cec文件,添加UART1這個(gè)feature。

搜索

ComponentType

(

Name ( "Serial" )

GUID ( {6563AD6C-E71C-11D4-B892-0050FC049781} )

MaxResolvedImpsAllowed( 999 )

Implementations

(

Implementation

(

Name ( "S32410 Serial UART" )

在其后面添加:

Implementation

(

Name ( "S32410 Serial UART1" )

GUID ( {7C4427A5-286C-4C7A-B687-4E3B364D079B} )

Description ( "Samsung S32410 serial UART controller." )

BSPPlatformDir ( "smdk2410" )

Version ( "5.0.0.0" )

Locale ( 0409 )

Vendor ( "Microsoft" )

Date ( "2003-1-13" )

SizeIsCPUDependent( 1 )

BuildMethods

(

BuildMethod

(

GUID ( {07DA2083-6261-4ED6-B5BB-70CF4D930D68} )

Step ( BSP )

CPU ( "ARMV4" )

CPU ( "ARMV4I" )

Action ( '#BUILD(SOURCES,"$(_WINCEROOT)PLATFORMSMDK2410driversserial")')

)

)

)

我感覺這個(gè)改不改沒什么關(guān)系,反正網(wǎng)上有人這樣改了,我也就改了,但是實(shí)際內(nèi)核定制時(shí)中并沒有添加上這個(gè)feature。

到這里,整個(gè)過程就結(jié)束了,耗費(fèi)了我整整一天!其實(shí)改動量并不大,但是調(diào)試一次光編譯就要15分鐘,還要下載,燒寫,啟動~唉,沒有仿真器就是麻煩。調(diào)了好多次沒有成功,就是在注冊表的中斷號那兒出了問題!

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

武漢2025年9月9日 /美通社/ -- 7月24日,2025慧聰跨業(yè)品牌巡展——湖北?武漢站在武漢中南花園酒店隆重舉辦!本次巡展由慧聰安防網(wǎng)、慧聰物聯(lián)網(wǎng)、慧聰音響燈光網(wǎng)、慧聰LED屏網(wǎng)、慧聰教育網(wǎng)聯(lián)合主辦,吸引了安防、...

關(guān)鍵字: AI 希捷 BSP 平板

上海2025年9月9日 /美通社/ -- 9月8日,移遠(yuǎn)通信宣布,其自研藍(lán)牙協(xié)議棧DynaBlue率先通過藍(lán)牙技術(shù)聯(lián)盟(SIG)BQB 6.1標(biāo)準(zhǔn)認(rèn)證。作為移遠(yuǎn)深耕短距離通信...

關(guān)鍵字: 藍(lán)牙協(xié)議棧 移遠(yuǎn)通信 COM BSP

上海2025年9月9日 /美通社/ -- 為全面落實(shí)黨中央、國務(wù)院和上海市委、市政府關(guān)于加快發(fā)展人力資源服務(wù)業(yè)的決策部署,更好發(fā)揮人力資源服務(wù)業(yè)賦能百業(yè)作用,8月29日,以"AI智領(lǐng) HR智鏈 靜候你來&quo...

關(guān)鍵字: 智能體 AI BSP 人工智能

北京2025年9月8日 /美通社/ -- 近日,易生支付與一汽出行達(dá)成合作,為其自主研發(fā)的"旗馭車管"車輛運(yùn)營管理平臺提供全流程支付通道及技術(shù)支持。此次合作不僅提升了平臺對百余家企業(yè)客戶的運(yùn)營管理效率...

關(guān)鍵字: 一汽 智能化 BSP SAAS

深圳2025年9月8日 /美通社/ -- 晶泰科技(2228.HK)今日宣布,由其助力智擎生技制藥(PharmaEngine, Inc.)發(fā)現(xiàn)的新一代PRMT5抑制劑PEP0...

關(guān)鍵字: 泰科 AI MT BSP

上海2025年9月5日 /美通社/ -- 由上海市經(jīng)濟(jì)和信息化委員會、上海市發(fā)展和改革委員會、上海市商務(wù)委員會、上海市教育委員會、上海市科學(xué)技術(shù)委員會指導(dǎo),東浩蘭生(集團(tuán))有限公司主辦,東浩蘭生會展集團(tuán)上海工業(yè)商務(wù)展覽有...

關(guān)鍵字: 電子 BSP 芯片 自動駕駛

推進(jìn)卓越制造,擴(kuò)大產(chǎn)能并優(yōu)化布局 蘇州2025年9月5日 /美通社/ --?耐世特汽車系統(tǒng)與蘇州工業(yè)園區(qū)管委會正式簽署備忘錄,以設(shè)立耐世特亞太總部蘇州智能制造項(xiàng)目。...

關(guān)鍵字: 智能制造 BSP 汽車系統(tǒng) 線控

慕尼黑和北京2025年9月4日 /美通社/ -- 寶馬集團(tuán)宣布,新世代首款量產(chǎn)車型BMW iX3將于9月5日全球首發(fā),9月8日震撼亮相慕尼黑車展。中國專屬版車型也將在年內(nèi)與大家見面,2026年在國內(nèi)投產(chǎn)。 寶馬集團(tuán)董事...

關(guān)鍵字: 寶馬 慕尼黑 BSP 數(shù)字化

北京2025年9月4日 /美通社/ --?在全球新一輪科技革命與產(chǎn)業(yè)變革的澎湃浪潮中,人工智能作為引領(lǐng)創(chuàng)新的核心驅(qū)動力,正以前所未有的深度與廣度重塑各行業(yè)發(fā)展格局。體育領(lǐng)域深度融入科技變革浪潮,駛?cè)霐?shù)字化、智能化轉(zhuǎn)型快車...

關(guān)鍵字: 人工智能 智能體 AI BSP

上海2025年9月2日 /美通社/ -- 近日,由 ABB、Moxa(摩莎科技)等八家企業(yè)在上海聯(lián)合發(fā)起并成功舉辦"2025 Ethernet-APL 技術(shù)應(yīng)用發(fā)展大會"。會議以"破界?融合...

關(guān)鍵字: ETHERNET 智能未來 BSP 工業(yè)通信
關(guān)閉