HardError feedback when trying to read the contents of PFlash in the code loaded into FlexNVM

cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

HardError feedback when trying to read the contents of PFlash in the code loaded into FlexNVM

Jump to solution
1,336 Views
FanJialin
Contributor II

Hello, I am using the S32K146 chip, and I encounter a HardError feedback when trying to read the contents of PFlash in the code loaded into FlexNVM.

It's strange that this issue is reproducible on some machines but not on others.

The specific code is as follows:

#define UPD_PFLAG_ADRRESS (0x000F0000)

uint8_t readFlag()

{

return (*(volatile uint8_t *)UPD_PFLAG_ADRRESS); //There is a HardError

}

Firstly, I would like to know if this error is caused by the limitation indicated in the diagram below.

#Table 36-30. Allowed simultaneous memory operations in [S32K-RM.pdf] datashee

FanJialin_0-1710499517514.png

 

If so, I attempted to move this code from FlexNVM to SRAM, but the issue still occurs.

Could you help me analyze the reason?

The specific code is as follows:

START_FUNCTION_DECLARATION_RAMSECTION

uint8_t readFlag()

{

return (*(volatile uint8_t *)UPD_PFLAG_ADRRESS); //There is also a HardError

} END_FUNCTION_DECLARATION_RAMSECTION

0 Kudos
Reply
1 Solution
1,083 Views
FanJialin
Contributor II

》The Erase Flash Sector command does the verification too.

Sorry for the late reply.

I agree with your view, and there is also an error verification in the Erase operation.

I will reorganize my process of writing to Flash to ensure that every step of the entire writing process is checked and retried.

Thank you very much for your assistance. I am closing this ticket.

Regards,
Fanjialin

View solution in original post

0 Kudos
Reply
9 Replies
1,216 Views
FanJialin
Contributor II

Hello @danielmartynek 
Thank you very much for your answer to Q1234, which has been very helpful for me to understand the S32 read and write operations.

I believe I have found the cause of the issue. Could you please confirm if my understanding is correct?

In simple terms, when rewriting Flash content, the following steps should be taken:

  1. FLASH_DRV_EraseSector
  2. FLASH_DRV_VerifySection (I missed this step)
  3. FLASH_DRV_Program
  4. FLASH_DRV_ProgramCheck

Due to missing step 2, there is a certain probability (although low, so it only occurs on some machines) that writing without complete erasure can put the Flash into an abnormal state. Subsequently, attempting to read it again will result in a HardError and the system will fail to start.

0 Kudos
Reply
1,191 Views
danielmartynek
NXP TechSupport
NXP TechSupport

Hi @FanJialin 

The Erase Flash Sector command does the verification too.

danielmartynek_0-1711116067729.png

Did you read the error status of the FLASH_DRV_EraseSector.

 

But yes, it can be verified further using the Verify Section command, refer to the S32K1xx Safety Manual.

 

Regards,

Daniel

 

 

 

 

0 Kudos
Reply
1,084 Views
FanJialin
Contributor II

》The Erase Flash Sector command does the verification too.

Sorry for the late reply.

I agree with your view, and there is also an error verification in the Erase operation.

I will reorganize my process of writing to Flash to ensure that every step of the entire writing process is checked and retried.

Thank you very much for your assistance. I am closing this ticket.

Regards,
Fanjialin

0 Kudos
Reply
1,296 Views
danielmartynek
NXP TechSupport
NXP TechSupport

Hi @FanJialin,

Do you see FSTAT[RDCOLERR] = 1?

What kind of fault exception is it?

https://community.nxp.com/t5/S32K-Knowledge-Base/Fault-handling-on-S32K14x/ta-p/1114447

 

Regards,

Daniel

0 Kudos
Reply
1,291 Views
FanJialin
Contributor II

@danielmartynek 
Thank you for reply.

The error displayed during my debugging using IAR is as shown in the figure, it should be HardFault_Handler.

FanJialin_0-1710818096700.png

 

Sorry,I don't know how to directly observe FSTAT[RDCOLERR] = 1. If the BaseAddress of FSTAT is 0x40020000, the value in the register is as follows.

FanJialin_1-1710818126462.png

 

When reading address 0x000F0000, I also found that for the faulty machines, if I use IAR to observe the content of the Dataflash address, the content is displayed as "-," as shown in the figure below.

FanJialin_2-1710818198390.png

 

For the normal machines, if I use IAR to observe the content of the Dataflash address, the content is not displayed as "-", as shown in the figure below.

FanJialin_3-1710818360490.png

 

0 Kudos
Reply
1,272 Views
danielmartynek
NXP TechSupport
NXP TechSupport

Hello @FanJialin,

The FSTAT register is at 0x40020080

danielmartynek_0-1710851623604.png

The screenshot you posted does not show that.

I don't use IAR, so I don't know what peripherals register view is there.

 

What is the value in the Cortex M4 Configurable Fault Status Register (CSFR)?

 

In general, the DFlash is a flash block that can be read while other flash block is read/programmed.

However, there is just one crossbar switch slave port for the flash controler. Either DFlash or PFlash can be read at a time.

danielmartynek_1-1710851906260.png

Have you tried disabling/masking interrupts before the flash operation?

The vector table and the interrupt routines must not be in the flash that is being programmed.

Also, the ISRs must not access any data in that block.

 

Regards,

Daniel

 

 

 

0 Kudos
Reply
859 Views
NXP2
Contributor I
Hello, I have some problems when operating FlexNVM partitions. I hope to get your reply. The questions are as follows:
In my application, Flexram is used as an emulated EEPROM, partitioning as follows using 32k for DFLASH and 32k for EFLASH. boot needs to write some flag bits to DFLASH, after writing. Start running my application, my application needs to perform three steps to read the flag bit, partition, read the flag bit, there is a problem in the process. The flag bit can be read normally before the partition, but after the partition is erased when reading the flag bit, the read content is full FF. I am not quite clear what is the reason for this operation, I hope you can tell me the reason and the solution.



void BswM_Eeeprom_Init(void)
{
status_t ret;
//ret定义为全局变量
//initial flash
ret = FLASH_DRV_Init(&Flash_Cfg_InitConfig0,&flashSSDConfig);
DEV_ASSERT(STATUS_SUCCESS == ret);

///若未分配EEE,则执行分配指令
if (flashSSDConfig.EEESize == 0u) //检查FlexRAM是否已配置为EEPROM,为0表示目前是传统RAM
{

ret = FLASH_DRV_DEFlashPartition(&flashSSDConfig, 0x2u, 0x3u, 0x0u, false, true); //分区
DEV_ASSERT(STATUS_SUCCESS == ret);
/* Re-initialize the driver to update the new EEPROM configuration */
ret = FLASH_DRV_Init(&Flash_Cfg_InitConfig0,&flashSSDConfig);
DEV_ASSERT(STATUS_SUCCESS == ret);

ret = FLASH_DRV_SetFlexRamFunction(&flashSSDConfig, EEE_ENABLE, 0x00u, &status);
// ret = FLASH_DRV_SetFlexRamFunction(&flashSSDConfig, EEE_ENABLE, 0x00u, NULL);
DEV_ASSERT(STATUS_SUCCESS == ret);
}
else /* FLexRAM is already configured as EEPROM */
{
ret = FLASH_DRV_SetFlexRamFunction(&flashSSDConfig, EEE_ENABLE, 0x00u, NULL);
DEV_ASSERT(STATUS_SUCCESS == ret);
}
}
0 Kudos
Reply
1,256 Views
FanJialin
Contributor II

Hello @danielmartynek 
Thanks for your reply.Could you please help me further confirm the following questions?

Q1:

FanJialin_0-1710916823704.png

 

》The FSTAT register is at 0x40020080
Sorry,I don't understand.
As the screenshot,the base address is 4002_0000h,and the offset is 0h(Reset value is 80h).
So The FSTAT register is at 0x40020000,not 0x40020080.

Q2:

》What is the value in the Cortex M4 Configurable Fault Status Register (CSFR)?

Sorry,I can't find [CSFR] description in the datasheet.
Can you tell me how to confirm the value of [CSFR]?

Q3:

FanJialin_1-1710918545294.png

》In general, the DFlash is a flash block that can be read while other flash block is read/programmed.

》However, there is just one core that can access a single block at a time.

In that case,I still don't understand what kind of operation the "NG" marked in the red circle in the diagram prohibits.

Could you further explain it to me?

Q4:

》Have you tried disabling/masking interrupts before the flash operation?
Does this restriction only refer to write operations?Is it necessary before flash read operation?

0 Kudos
Reply
1,248 Views
danielmartynek
NXP TechSupport
NXP TechSupport

Hello @FanJialin,

1.

I'm sorry, you are right. So, the RDCOLERR is not detected during the flash operation then.

2.

CFSR is a core register:

https://developer.arm.com/documentation/ddi0439/b/System-Control/Register-summary

3.

The table is a bit confusing in this regard.

It does not prohibit reading DFlash while PFlash is read.

But practically either the CM4 core or DMA (not both at the same time, crossbar arbitration) can access just DFlash or PFlash at a time via the Flash controller.

However, while the flash controller programs/erases PFlash, the core/DMA can read DFlash, this is marked as OK in the table.

danielmartynek_0-1710944694314.png

4.

It applies to write (program/erase) operations only. Becasue these operations are done by the flash controller. So, while the flash controller is performing operations at the block, the core / DMA must not access the block.

 

Regards,

Daniel

 

0 Kudos
Reply