S32K3 Find the Currently Executing core ID

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

S32K3 Find the Currently Executing core ID

跳至解决方案
2,228 次查看
jonnyWHIS
Contributor III

Hi there,

I have a function that i'd like to behave slightly differently depending on which S32K3 core invokes it. At the moment i have a function returning the value of what i thought was the correct register.

In the S32K3xx RM, under MCM Register Descriptions (Chapter 6.4.1) it mentions a Processor Identifier (PID) register. However if i read the value of this register, it returns 0 regardless of which core the read is performed on.

I'm assuming that this is not the correct register, but i cannot find a more relevant one in the manual. Could you advise :

- if it is possible to find the currently executing core ID, and if so

- what register/driver function is required to do this

 

I have both cores running no problem, but maybe there's something more i need to do in the .mex file?

Any help would be appreciated.

0 项奖励
回复
1 解答
2,204 次查看
lukaszadrapa
NXP TechSupport
NXP TechSupport

Hi @jonnyWHIS 

The name of the PID register is wrong, I will ask to update it. It should be called Process Identifier, not Processor Identifier. The description of the bits is then correct. It says:
"Process Identifier
Identifies the CPU process."

It can't be used to identify which core is running a code.

For this purpose, you can use register CPXNUM in MCM at address 0x40260004.

It's used in startup files, for example. You can find code like this in startup code:

/* If this is the primary core, initialize data and bss */
ldr r0, =0x40260004
ldr r1,[r0]

ldr r0, =MAIN_CORE
cmp r1,r0
beq _INIT_DATA_BSS

Regards,
Lukas

在原帖中查看解决方案

0 项奖励
回复
2 回复数
2,205 次查看
lukaszadrapa
NXP TechSupport
NXP TechSupport

Hi @jonnyWHIS 

The name of the PID register is wrong, I will ask to update it. It should be called Process Identifier, not Processor Identifier. The description of the bits is then correct. It says:
"Process Identifier
Identifies the CPU process."

It can't be used to identify which core is running a code.

For this purpose, you can use register CPXNUM in MCM at address 0x40260004.

It's used in startup files, for example. You can find code like this in startup code:

/* If this is the primary core, initialize data and bss */
ldr r0, =0x40260004
ldr r1,[r0]

ldr r0, =MAIN_CORE
cmp r1,r0
beq _INIT_DATA_BSS

Regards,
Lukas

0 项奖励
回复
2,176 次查看
jonnyWHIS
Contributor III

Hi Lukas, brill thank you, using that CPXNUM register has worked for me.

0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-1944389%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3ES32K3%E6%9F%A5%E6%89%BE%E5%BD%93%E5%89%8D%E6%AD%A3%E5%9C%A8%E6%89%A7%E8%A1%8C%E7%9A%84%E6%A0%B8%E5%BF%83ID%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1944389%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E6%82%A8%E5%A5%BD%EF%BC%8C%3C%2FP%3E%3CP%3E%E6%88%91%E6%9C%89%E4%B8%80%E4%B8%AA%E5%87%BD%E6%95%B0%EF%BC%8C%E6%88%91%E5%B8%8C%E6%9C%9B%E5%AE%83%E7%9A%84%E8%A1%8C%E4%B8%BA%E6%A0%B9%E6%8D%AE%E8%B0%83%E7%94%A8%E5%AE%83%E7%9A%84%20S32K3%20%E6%A0%B8%E5%BF%83%E8%80%8C%E7%95%A5%E6%9C%89%E4%B8%8D%E5%90%8C%E3%80%82%E7%9B%AE%E5%89%8D%E6%88%91%E6%9C%89%E4%B8%80%E4%B8%AA%E5%87%BD%E6%95%B0%E8%BF%94%E5%9B%9E%E6%88%91%E8%AE%A4%E4%B8%BA%E6%AD%A3%E7%A1%AE%E7%9A%84%E5%AF%84%E5%AD%98%E5%99%A8%E7%9A%84%E5%80%BC%E3%80%82%3C%2FP%3E%3CP%3E%E5%9C%A8%20S32K3xx%20RM%20%E4%B8%AD%EF%BC%8C%E5%9C%A8%20MCM%20%E5%AF%84%E5%AD%98%E5%99%A8%E6%8F%8F%E8%BF%B0%EF%BC%88%E7%AC%AC%206.4.1%20%E7%AB%A0%EF%BC%89%E4%B8%8B%E6%8F%90%E5%88%B0%E4%BA%86%E4%B8%80%E4%B8%AA%3CSTRONG%3E%E5%A4%84%E7%90%86%E5%99%A8%E6%A0%87%E8%AF%86%E7%AC%A6%EF%BC%88PID%EF%BC%89%3C%2FSTRONG%3E%E5%AF%84%E5%AD%98%E5%99%A8%E3%80%82%E4%BD%86%E6%98%AF%E5%A6%82%E6%9E%9C%E6%88%91%E8%AF%BB%E5%8F%96%E8%AF%A5%E5%AF%84%E5%AD%98%E5%99%A8%E7%9A%84%E5%80%BC%EF%BC%8C%E6%97%A0%E8%AE%BA%E5%9C%A8%E5%93%AA%E4%B8%AA%E6%A0%B8%E5%BF%83%E4%B8%8A%E6%89%A7%E8%A1%8C%E8%AF%BB%E5%8F%96%EF%BC%8C%E5%AE%83%E9%83%BD%E4%BC%9A%E8%BF%94%E5%9B%9E%200%E3%80%82%3C%2FP%3E%3CP%3E%E6%88%91%E8%AE%A4%E4%B8%BA%E8%BF%99%E4%B8%8D%E6%98%AF%E6%AD%A3%E7%A1%AE%E7%9A%84%E5%AF%84%E5%AD%98%E5%99%A8%EF%BC%8C%E4%BD%86%E6%88%91%E5%9C%A8%E6%89%8B%E5%86%8C%E4%B8%AD%E6%89%BE%E4%B8%8D%E5%88%B0%E6%9B%B4%E7%9B%B8%E5%85%B3%E7%9A%84%E5%AF%84%E5%AD%98%E5%99%A8%E3%80%82%E6%82%A8%E8%83%BD%E5%90%A6%E5%BB%BA%E8%AE%AE%EF%BC%9A%3C%2FP%3E%3CP%3E-%20%E6%98%AF%E5%90%A6%E5%8F%AF%E4%BB%A5%E6%89%BE%E5%88%B0%E5%BD%93%E5%89%8D%E6%AD%A3%E5%9C%A8%E6%89%A7%E8%A1%8C%E7%9A%84%E6%A0%B8%E5%BF%83%20ID%EF%BC%8C%E5%A6%82%E6%9E%9C%E5%8F%AF%E4%BB%A5%3C%2FP%3E%3CP%3E-%20%E9%9C%80%E8%A6%81%E4%BB%80%E4%B9%88%E5%AF%84%E5%AD%98%E5%99%A8%2F%E9%A9%B1%E5%8A%A8%E7%A8%8B%E5%BA%8F%E5%87%BD%E6%95%B0%E6%9D%A5%E5%AE%9E%E7%8E%B0%E8%BF%99%E4%B8%80%E7%82%B9%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%E6%88%91%E7%9A%84%E4%B8%A4%E4%B8%AA%E6%A0%B8%E5%BF%83%E8%BF%90%E8%A1%8C%E9%83%BD%E6%B2%A1%E6%9C%89%E9%97%AE%E9%A2%98%EF%BC%8C%E4%BD%86%E4%B9%9F%E8%AE%B8%E6%88%91%E9%9C%80%E8%A6%81%E5%9C%A8%20.mex%20%E4%B8%AD%E5%81%9A%E6%9B%B4%E5%A4%9A%E7%9A%84%E4%BA%8B%E6%83%85%E6%96%87%E4%BB%B6%EF%BC%9F%3C%2FP%3E%3CP%3E%E4%BB%BB%E4%BD%95%E5%B8%AE%E5%8A%A9%E9%83%BD%E5%B0%86%E4%B8%8D%E8%83%9C%E6%84%9F%E6%BF%80%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1945313%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9AS32K3%E6%9F%A5%E6%89%BE%E5%BD%93%E5%89%8D%E6%AD%A3%E5%9C%A8%E6%89%A7%E8%A1%8C%E7%9A%84%E6%A0%B8%E5%BF%83ID%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1945313%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%97%A8%EF%BC%8C%E5%8D%A2%E5%8D%A1%E6%96%AF%EF%BC%8C%E9%9D%9E%E5%B8%B8%E6%84%9F%E8%B0%A2%EF%BC%8C%E4%BD%BF%E7%94%A8%E9%82%A3%E4%B8%AA%20CPXNUM%20%E5%AF%84%E5%AD%98%E5%99%A8%E5%AF%B9%E6%88%91%E6%9D%A5%E8%AF%B4%E5%BE%88%E6%9C%89%E7%94%A8%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1944541%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9AS32K3%E6%9F%A5%E6%89%BE%E5%BD%93%E5%89%8D%E6%AD%A3%E5%9C%A8%E6%89%A7%E8%A1%8C%E7%9A%84%E6%A0%B8%E5%BF%83ID%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1944541%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F213014%22%20target%3D%22_blank%22%3E%40jonnyWHIS%3C%2FA%3E%3C%2FP%3E%0A%3CP%3EPID%E5%AF%84%E5%AD%98%E5%99%A8%E7%9A%84%E5%90%8D%E7%A7%B0%E6%98%AF%E9%94%99%E8%AF%AF%E7%9A%84%EF%BC%8C%E6%88%91%E4%BC%9A%E8%A6%81%E6%B1%82%E6%9B%B4%E6%96%B0%E5%AE%83%E3%80%82%E5%AE%83%E5%BA%94%E8%AF%A5%E8%A2%AB%E7%A7%B0%E4%B8%BA%E8%BF%9B%E7%A8%8B%E6%A0%87%E8%AF%86%E7%AC%A6%EF%BC%8C%E8%80%8C%E4%B8%8D%E6%98%AF%E5%A4%84%E7%90%86%E5%99%A8%E6%A0%87%E8%AF%86%E7%AC%A6%E3%80%82%E9%82%A3%E4%B9%88%E4%BD%8D%E7%9A%84%E6%8F%8F%E8%BF%B0%E5%B0%B1%E6%98%AF%E6%AD%A3%E7%A1%AE%E7%9A%84%E3%80%82%E5%AE%83%E8%AF%B4%EF%BC%9A%3CBR%20%2F%3E%20%E2%80%9C%E8%BF%9B%E7%A8%8B%E6%A0%87%E8%AF%86%E7%AC%A6%3CBR%20%2F%3E%E8%AF%86%E5%88%AB%20CPU%20%E8%BF%9B%E7%A8%8B%E3%80%82%E2%80%9D%3C%2FP%3E%0A%3CP%3E%E5%AE%83%E4%B8%8D%E8%83%BD%E7%94%A8%E4%BA%8E%E8%AF%86%E5%88%AB%E5%93%AA%E4%B8%AA%E6%A0%B8%E5%BF%83%E6%AD%A3%E5%9C%A8%E8%BF%90%E8%A1%8C%E4%BB%A3%E7%A0%81%E3%80%82%3C%2FP%3E%0A%3CP%3E%E4%B8%BA%E6%AD%A4%EF%BC%8C%E6%82%A8%E5%8F%AF%E4%BB%A5%E4%BD%BF%E7%94%A8%20MCM%20%E4%B8%AD%E5%9C%B0%E5%9D%80%200x40260004%20%E7%9A%84%E5%AF%84%E5%AD%98%E5%99%A8%20CPXNUM%E3%80%82%3C%2FP%3E%0A%3CP%3E%E4%BE%8B%E5%A6%82%EF%BC%8C%E5%AE%83%E7%94%A8%E4%BA%8E%E5%90%AF%E5%8A%A8%E6%96%87%E4%BB%B6%E3%80%82%E6%82%A8%E5%8F%AF%E4%BB%A5%E5%9C%A8%E5%90%AF%E5%8A%A8%E4%BB%A3%E7%A0%81%E4%B8%AD%E6%89%BE%E5%88%B0%E8%BF%99%E6%A0%B7%E7%9A%84%E4%BB%A3%E7%A0%81%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%2F*%20%E5%A6%82%E6%9E%9C%E8%BF%99%E6%98%AF%E4%B8%BB%E6%A0%B8%E5%BF%83%EF%BC%8C%E5%88%99%E5%88%9D%E5%A7%8B%E5%8C%96%E6%95%B0%E6%8D%AE%E5%92%8Cbss%20*%2F%3CBR%20%2F%3E%20ldr%20r0%EF%BC%8C%3D0x40260004%3CBR%20%2F%3E%20ldr%20r1%2C%5Br0%5D%3C%2FP%3E%0A%3CP%3Eldr%20r0%2C%20%3DMAIN_CORE%3CBR%20%2F%3E%20cmp%20r1%2Cr0%3CBR%20%2F%3E%20beq%20_INIT_DATA_BSS%3C%2FP%3E%0A%3CP%3E%E9%97%AE%E5%80%99%EF%BC%8C%3CBR%20%2F%3E%E5%8D%A2%E5%8D%A1%E6%96%AF%3C%2FP%3E%3C%2FLINGO-BODY%3E