S32K312-Problem with C40CheckLockDomainID function

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

S32K312-Problem with C40CheckLockDomainID function

跳至解决方案
14,021 次查看
Simon-Liu
Contributor V

Hello

When I looked at the C40 function, I found that there is such a judgment in the function C40_Ip_CheckLockDomainID: if ((uint32)VirtualSector != FLS_MAX_VIRTUAL_SECTOR)
This judgment means that the parameter VirtualSector passed in cannot be equal to FLS_MAX_VIRTUAL_SECTOR, but the value of the FLS_MAX_VIRTUAL_SECTOR macro is 271, which is a legal Sector. So is this judgment incorrect?
The attachment is a screenshot of the function logic and macro, please check it out.

BestRegards

Simon

0 项奖励
回复
1 解答
14,003 次查看
VaneB
NXP TechSupport
NXP TechSupport

Hi @Simon-Liu 

Sorry for the inconvenience. These are typos, please make sure that FLS_MAX_VIRTUAL_SECTOR located in C40_Ip_Cfg.h has the same value as the C40_UTEST_ARRAY_0_S000 and that C40_SECTOR_ERROR is one value greater than C40_UTEST_ARRAY_0_S000. 

For example instead of:

#define FLS_MAX_VIRTUAL_SECTOR              (271U)
… 
#define C40_UTEST_ARRAY_0_S000              (272U)    
#define C40_SECTOR_ERROR                    (272U)  

Needs to be:

#define FLS_MAX_VIRTUAL_SECTOR              (272U) 
…
#define C40_UTEST_ARRAY_0_S000              (272U)    
#define C40_SECTOR_ERROR                    (273U)    

Note: every time you update the code by ConfigTool these will return to their original value so you will have to change again. 

 

B.R.

VaneB 

在原帖中查看解决方案

15 回复数
14,004 次查看
VaneB
NXP TechSupport
NXP TechSupport

Hi @Simon-Liu 

Sorry for the inconvenience. These are typos, please make sure that FLS_MAX_VIRTUAL_SECTOR located in C40_Ip_Cfg.h has the same value as the C40_UTEST_ARRAY_0_S000 and that C40_SECTOR_ERROR is one value greater than C40_UTEST_ARRAY_0_S000. 

For example instead of:

#define FLS_MAX_VIRTUAL_SECTOR              (271U)
… 
#define C40_UTEST_ARRAY_0_S000              (272U)    
#define C40_SECTOR_ERROR                    (272U)  

Needs to be:

#define FLS_MAX_VIRTUAL_SECTOR              (272U) 
…
#define C40_UTEST_ARRAY_0_S000              (272U)    
#define C40_SECTOR_ERROR                    (273U)    

Note: every time you update the code by ConfigTool these will return to their original value so you will have to change again. 

 

B.R.

VaneB 

13,981 次查看
Simon-Liu
Contributor V

Hello, @VaneB 

There is another problem of this function:

There is such a judgment in the function C40_Ip_CheckLockDomainID (the complete code is as shown in the attached picture):
if ( (0U != (CheckRegister & C40_Ip_u32BitPosition)) && (TempLockMasterRegister != 0U) )
My understanding of this is that if the SETSLOCK of the corresponding Sector is not set to 1, or the value of LOCKMASTER is 0, it means that the Sector is not locked/protected and can be erased.
I have questions about the second condition of this judgment. Why does the value of LOCKMASTER 0 also mean that the Sector is not locked? The MasterID may also be 0 (as shown in the attached picture). Is this judgment condition written wrong?

 

BestRegards

Simon

 

0 项奖励
回复
13,973 次查看
VaneB
NXP TechSupport
NXP TechSupport

@Simon-Liu 

You are correct TempLockMasterRegister corresponds to PFCBLKU_LOCKMASTER_S or PFCBLKn_LOCKMASTER_Sn, this register provides the status of the sector program/erase lock bit domain ID owner (PFCBLKn_SPELOCK or PFCBLKU_SPELOCK).

0 项奖励
回复
13,915 次查看
Simon-Liu
Contributor V

@VaneB 

So what should the logic of this judgment be? How to modify it?

0 项奖励
回复
13,875 次查看
VaneB
NXP TechSupport
NXP TechSupport

Hi @Simon-Liu 

I had consulted the corresponding team about this topic. 

These conditions are considered just when XRDC is enabled and the PFLASH domain has been changed. Otherwise, the domain will always be 0. 

0 项奖励
回复
13,866 次查看
Simon-Liu
Contributor V

Hi @VaneB 

So if this is the case, would something go wrong:
XRDC is enabled, and the MasterID locking Flash is 0.
In this case, the value of the variable TempLockMasterRegister is also 0.

0 项奖励
回复
13,347 次查看
VaneB
NXP TechSupport
NXP TechSupport

Hi @Simon-Liu 

No, if TempLockMasterRegister is 0, the return value of the function will be STATUS_C40_IP_SUCCESS. You should not have any problems. Unless you enable XRDC and change the domain and this domain does not match the value you gave to DomainIdValue, if this is the case the function will return STATUS_C40_IP_ERROR.

0 项奖励
回复
13,340 次查看
Simon-Liu
Contributor V

Hi @VaneB 

The situation I mentioned before is that you enable XRDC and change the domain, and the MasterID is 0, then ERROR should be returned the next time you access using another MasterID, but according to the current logic, SUCCESS is returned because TempLockMasterRegister is 0.

0 项奖励
回复
13,311 次查看
VaneB
NXP TechSupport
NXP TechSupport

Hi @Simon-Liu 

The C40_Ip_CheckLockDomainID function will return a STATUS_C40_IP_ERROR if the actual domain obtained by C40_Ip_CheckLockDomainID_CheckRegister() and the operation performed to assign a value to LockDomainIDValue does not match the provided domain ID value (DomainIdValue).

0 项奖励
回复
13,281 次查看
Simon-Liu
Contributor V

Hi @VaneB 

I have mentioned it many times. According to the current logic, if the actual domain ID obtained through C40_Ip_CheckLockDomainID_CheckRegister() is 0, STATUS_C40_IP_SUCCESS will be returned directly, and it will not be judged at all whether the actual domain ID matches the provided domain ID value.

13,190 次查看
Simon-Liu
Contributor V

Hi @VaneB 

If my understanding is correct, there is something wrong with the logic in the code now, right? How to modify it?

 

BestRegards

Simon

0 项奖励
回复
13,155 次查看
VaneB
NXP TechSupport
NXP TechSupport

Hi @Simon-Liu 

At the moment we do not have any bug reports related to this function. So, we do not recommend modifying. If you encounter a problem, let us know so the information can be sent to the corresponding team.

0 项奖励
回复
13,087 次查看
Simon-Liu
Contributor V

Hi @VaneB 

OK, I'll contact you again if I run into problems.

 

BestRegards

Simon

0 项奖励
回复
13,962 次查看
Simon-Liu
Contributor V

Hello @VaneB 

The variable TempLockMasterRegister does not correspond to the value of PFCBLKn_SPELOCK, but the value of PFCBLK_LOCKMASTER_S, so the condition (TempLockMasterRegister!=0U) only means that the value of MasterID is not 0. What can this be used to determine?

 

BestRegards

Simon

0 项奖励
回复
13,990 次查看
Simon-Liu
Contributor V

Hi, @VaneB 

Thank you for your reply. Will this error be corrected in subsequent RTD releases?

BestRegards,

Simon

0 项奖励
回复