S32K311 UTest Programming: RWE Error and Crash During Programming

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

S32K311 UTest Programming: RWE Error and Crash During Programming

311件の閲覧回数
Enoch_D
Contributor I

I am working on UTest programming on the S32K311 Microcontroller, and I am encountering a Read-While-Write Error (RWE) along with a controller crash during flash programming.

Issue:
After triggering the UTest programming sequence:

The controller jumps to the default handler (crash)
The RWE (Read While Write Error) flag is set

Context:
Application is executing from PFlash @ 0x00480000
UTest programming is initiated while running from PFlash
The actual trigger function (EHV set + polling) is executed from RAM

Implementation Flow:
1. Initialization & Preparation (FLASH_gSetPublicKey_Prepare)
Unlock UTest sector: PFLASH.PFCBLKU_SPELOCK[0].R &= ~(1U << 0);
Reset operation mode bits:EHV = 0,PGM = 0,ERS = 0
Clear status flags
Load target address: PFLASH.PFCPGM_PEADR_L.R = 0x1B000100U;
Load data into flash registers:
for (i = 0U; i < FLASH_lNumOfWords; i++)
{
FLASH.DATA[i].R = FLASH_pSrc[i];
}
Enable program mode: FLASH.MCR.B.PGM = 1U;

2. Programming Execution (from RAM) (FLASH_gSetPublicKey_Trigger)
Start programming: FLASH.MCR.B.EHV = 1U;
Poll until completion: Wait for DONE = 1
Stop programming:
FLASH.MCR.B.EHV = 0U;
FLASH.MCR.B.PGM = 0U;
Re-lock UTest sector

Observations:
Even though the trigger function runs from RAM, the system still:
Encounters RWE error & Jumps to default handler

Based on the above flow, I would appreciate if you could help identify the exact cause of the RWE fault and suggest the necessary corrections to ensure reliable UTest programming.

Thanks.

0 件の賞賛
返信
1 返信

240件の閲覧回数
davidtosenovjan
NXP TechSupport
NXP TechSupport

Do you have disabled interrupts? Also flash prefetching and cache needs to be disabled as speculative or prefetch access to flash block 0 can occur what is same block as UTEST.

0 件の賞賛
返信
%3CLINGO-SUB%20id%3D%22lingo-sub-2351536%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3ES32K311%20UTest%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%EF%BC%9A%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E4%B8%AD%E3%81%AERWE%E3%82%A8%E3%83%A9%E3%83%BC%E3%81%A8%E3%82%AF%E3%83%A9%E3%83%83%E3%82%B7%E3%83%A5%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2351536%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E7%A7%81%E3%81%AFS32K311%E3%83%9E%E3%82%A4%E3%82%AF%E3%83%AD%E3%82%B3%E3%83%B3%E3%83%88%E3%83%AD%E3%83%BC%E3%83%A9%E4%B8%8A%E3%81%A7UTest%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E3%81%AB%E5%8F%96%E3%82%8A%E7%B5%84%E3%82%93%E3%81%A7%E3%81%84%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81%E3%83%95%E3%83%A9%E3%83%83%E3%82%B7%E3%83%A5%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E4%B8%AD%E3%81%AB%E8%AA%AD%E3%81%BF%E5%8F%96%E3%82%8A%E6%9B%B8%E3%81%8D%E8%BE%BC%E3%81%BF%E3%82%A8%E3%83%A9%E3%83%BC%EF%BC%88RWE%EF%BC%89%E3%81%A8%E3%82%B3%E3%83%B3%E3%83%88%E3%83%AD%E3%83%BC%E3%83%A9%E3%81%AE%E3%82%AF%E3%83%A9%E3%83%83%E3%82%B7%E3%83%A5%E3%81%8C%E7%99%BA%E7%94%9F%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E5%95%8F%E9%A1%8C%EF%BC%9A%3CBR%20%2F%3E%20UTest%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E3%82%B7%E3%83%BC%E3%82%B1%E3%83%B3%E3%82%B9%E3%82%92%E3%83%88%E3%83%AA%E3%82%AC%E3%83%BC%E3%81%97%E3%81%9F%E5%BE%8C%EF%BC%9A%3C%2FP%3E%3CP%3E%E3%82%B3%E3%83%B3%E3%83%88%E3%83%AD%E3%83%BC%E3%83%A9%E3%81%AF%E3%83%87%E3%83%95%E3%82%A9%E3%83%AB%E3%83%88%E3%83%8F%E3%83%B3%E3%83%89%E3%83%A9%EF%BC%88%E3%82%AF%E3%83%A9%E3%83%83%E3%82%B7%E3%83%A5%EF%BC%89%E3%81%AB%E3%82%B8%E3%83%A3%E3%83%B3%E3%83%97%E3%81%97%E3%81%BE%E3%81%99%3CBR%20%2F%3ERWE%EF%BC%88Read%20While%20Write%20Error%EF%BC%89%E3%83%95%E3%83%A9%E3%82%B0%E3%81%8C%E8%A8%AD%E5%AE%9A%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%3C%2FP%3E%3CP%3E%E3%82%B3%E3%83%B3%E3%83%86%E3%82%AF%E3%82%B9%E3%83%88%EF%BC%9A%3CBR%20%2F%3E%E3%82%A2%E3%83%97%E3%83%AA%E3%82%B1%E3%83%BC%E3%82%B7%E3%83%A7%E3%83%B3%E3%81%AFPFlash%E3%81%AE%E3%82%A2%E3%83%89%E3%83%AC%E3%82%B90x00480000%E3%81%8B%E3%82%89%E5%AE%9F%E8%A1%8C%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%3CBR%20%2F%3EUTest%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E3%81%AFPFlash%E3%81%8B%E3%82%89%E5%AE%9F%E8%A1%8C%E4%B8%AD%E3%81%AB%E9%96%8B%E5%A7%8B%E3%81%95%E3%82%8C%E3%81%BE%E3%81%99%3CBR%20%2F%3E%E5%AE%9F%E9%9A%9B%E3%81%AE%E3%83%88%E3%83%AA%E3%82%AC%E3%83%BC%E6%A9%9F%E8%83%BD%EF%BC%88EHV%E8%A8%AD%E5%AE%9A%EF%BC%8B%E3%83%9D%E3%83%BC%E3%83%AA%E3%83%B3%E3%82%B0%EF%BC%89%E3%81%AFRAM%E3%81%8B%E3%82%89%E5%AE%9F%E8%A1%8C%E3%81%95%E3%82%8C%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E5%AE%9F%E8%A3%85%E3%83%95%E3%83%AD%E3%83%BC%EF%BC%9A%3CBR%20%2F%3E%201.%20%E5%88%9D%E6%9C%9F%E5%8C%96%E3%81%A8%E6%BA%96%E5%82%99%20(FLASH_gSetPublicKey_Prepare)%3CBR%20%2F%3E%20UTest%E3%82%BB%E3%82%AF%E3%82%BF%E3%83%BC%E3%81%AE%E3%83%AD%E3%83%83%E3%82%AF%E3%82%92%E8%A7%A3%E9%99%A4%E3%81%97%E3%81%BE%E3%81%99%3A%20PFLASH.PFCBLKU_SPELOCK%5B0%5D.R%20%26amp%3B%3D%20~(1U%20%26lt%3B%26lt%3B%200)%3B%3CBR%20%2F%3E%E3%83%AA%E3%82%BB%E3%83%83%E3%83%88%E5%8B%95%E4%BD%9C%E3%83%A2%E3%83%BC%E3%83%89%E3%83%93%E3%83%83%E3%83%88%EF%BC%9AEHV%20%3D%200%E3%80%81PGM%20%3D%200%E3%80%81ERS%20%3D%200%3CBR%20%2F%3E%E3%82%B9%E3%83%86%E3%83%BC%E3%82%BF%E3%82%B9%E3%83%95%E3%83%A9%E3%82%B0%E3%82%92%E3%82%AF%E3%83%AA%E3%82%A2%E3%81%99%E3%82%8B%3CBR%20%2F%3E%E3%83%AD%E3%83%BC%E3%83%89%E5%AF%BE%E8%B1%A1%E3%82%A2%E3%83%89%E3%83%AC%E3%82%B9%3A%20PFLASH.PFCPGM_PEADR_L.R%20%3D%200x1B000100U%3B%3CBR%20%2F%3E%E3%83%95%E3%83%A9%E3%83%83%E3%82%B7%E3%83%A5%E3%83%AC%E3%82%B8%E3%82%B9%E3%82%BF%E3%81%AB%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E3%83%AD%E3%83%BC%E3%83%89%E3%81%99%E3%82%8B%EF%BC%9A%3CBR%20%2F%3E%20for%20(i%20%3D%200U%3B%20i%20%26lt%3B%20FLASH_lNumOfWords%3B%20i%2B%2B)%3CBR%20%2F%3E%E3%83%A4%E3%83%BC%E3%82%B8%E3%83%A5%3CBR%20%2F%3EFLASH.DATA%5Bi%5D.R%20%3D%20FLASH_pSrc%5Bi%5D%3B%3CBR%20%2F%3E%20%7D%3CBR%20%2F%3E%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%A0%E3%83%A2%E3%83%BC%E3%83%89%E3%82%92%E6%9C%89%E5%8A%B9%E3%81%AB%E3%81%99%E3%82%8B%3A%20FLASH.MCR.B.PGM%20%3D%201U%3B%3C%2FP%3E%3CP%3E2.%20%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%A0%E3%81%AE%E5%AE%9F%E8%A1%8C%EF%BC%88RAM%E3%81%8B%E3%82%89%EF%BC%89%EF%BC%88FLASH_gSetPublicKey_Trigger%EF%BC%89%3CBR%20%2F%3E%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E3%82%92%E9%96%8B%E5%A7%8B%E3%81%97%E3%81%BE%E3%81%99%3A%20FLASH.MCR.B.EHV%20%3D%201U%3B%3CBR%20%2F%3E%E5%AE%8C%E4%BA%86%E3%81%99%E3%82%8B%E3%81%BE%E3%81%A7%E3%83%9D%E3%83%BC%E3%83%AA%E3%83%B3%E3%82%B0%EF%BC%9ADONE%20%3D%201%E3%81%AB%E3%81%AA%E3%82%8B%E3%81%BE%E3%81%A7%E5%BE%85%E6%A9%9F%3CBR%20%2F%3E%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E3%82%92%E5%81%9C%E6%AD%A2%E3%81%97%E3%81%BE%E3%81%99%3A%3CBR%20%2F%3E%20FLASH.MCR.B.EHV%20%3D%200U%3B%3CBR%20%2F%3E%20FLASH.MCR.B.PGM%20%3D%200U%3B%3CBR%20%2F%3E%20UTest%E3%82%BB%E3%82%AF%E3%82%BF%E3%83%BC%E3%82%92%E5%86%8D%E3%83%AD%E3%83%83%E3%82%AF%3C%2FP%3E%3CP%3E%E8%A6%B3%E5%AF%9F%E7%B5%90%E6%9E%9C%EF%BC%9A%3CBR%20%2F%3E%E3%83%88%E3%83%AA%E3%82%AC%E3%83%BC%E9%96%A2%E6%95%B0%E3%81%AFRAM%E3%81%8B%E3%82%89%E5%AE%9F%E8%A1%8C%E3%81%95%E3%82%8C%E3%82%8B%E3%81%8C%E3%80%81%E3%82%B7%E3%82%B9%E3%83%86%E3%83%A0%E3%81%AF%E3%81%BE%E3%81%A0%E6%AC%A1%E3%81%AE%E3%81%93%E3%81%A8%E3%82%92%E8%A1%8C%E3%81%86%E3%80%82%3CBR%20%2F%3E%20RWE%E3%82%A8%E3%83%A9%E3%83%BC%E3%81%8C%E7%99%BA%E7%94%9F%E3%81%97%E3%80%81%E3%83%87%E3%83%95%E3%82%A9%E3%83%AB%E3%83%88%E3%83%8F%E3%83%B3%E3%83%89%E3%83%A9%E3%81%AB%E3%82%B8%E3%83%A3%E3%83%B3%E3%83%97%E3%81%97%E3%81%BE%E3%81%99%3C%2FP%3E%3CP%3E%E4%B8%8A%E8%A8%98%E3%81%AE%E6%B5%81%E3%82%8C%E3%81%AB%E5%9F%BA%E3%81%A5%E3%81%8D%E3%80%81RWE%E9%9A%9C%E5%AE%B3%E3%81%AE%E6%AD%A3%E7%A2%BA%E3%81%AA%E5%8E%9F%E5%9B%A0%E3%82%92%E7%89%B9%E5%AE%9A%E3%81%97%E3%80%81UTest%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E3%81%AE%E4%BF%A1%E9%A0%BC%E6%80%A7%E3%82%92%E7%A2%BA%E4%BF%9D%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%E5%BF%85%E8%A6%81%E3%81%AA%E4%BF%AE%E6%AD%A3%E6%A1%88%E3%82%92%E3%81%94%E6%8F%90%E6%A1%88%E3%81%84%E3%81%9F%E3%81%A0%E3%81%91%E3%82%8C%E3%81%B0%E5%B9%B8%E3%81%84%E3%81%A7%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E3%81%82%E3%82%8A%E3%81%8C%E3%81%A8%E3%81%86%E3%81%94%E3%81%96%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2352917%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20S32K311%20UTest%20Programming%3A%20RWE%20Error%20and%20Crash%20During%20Programming%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2352917%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%89%B2%E3%82%8A%E8%BE%BC%E3%81%BF%E3%82%92%E7%84%A1%E5%8A%B9%E3%81%AB%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%81%8B%EF%BC%9F%E3%81%BE%E3%81%9F%E3%80%81%E3%83%95%E3%83%A9%E3%83%83%E3%82%B7%E3%83%A5%E3%81%AE%E3%83%97%E3%83%AA%E3%83%95%E3%82%A7%E3%83%83%E3%83%81%E3%81%A8%E3%82%AD%E3%83%A3%E3%83%83%E3%82%B7%E3%83%A5%E3%82%92%E7%84%A1%E5%8A%B9%E3%81%AB%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%E3%81%93%E3%82%8C%E3%81%AF%E3%80%81UTEST%20%E3%81%A8%E5%90%8C%E3%81%98%E3%83%96%E3%83%AD%E3%83%83%E3%82%AF%E3%81%A7%E3%81%82%E3%82%8B%E3%83%95%E3%83%A9%E3%83%83%E3%82%B7%E3%83%A5%E3%83%96%E3%83%AD%E3%83%83%E3%82%AF%200%20%E3%81%B8%E3%81%AE%E6%8A%95%E6%A9%9F%E7%9A%84%E3%82%A2%E3%82%AF%E3%82%BB%E3%82%B9%E3%81%BE%E3%81%9F%E3%81%AF%E3%83%97%E3%83%AA%E3%83%95%E3%82%A7%E3%83%83%E3%83%81%E3%82%A2%E3%82%AF%E3%82%BB%E3%82%B9%E3%81%8C%E7%99%BA%E7%94%9F%E3%81%99%E3%82%8B%E5%8F%AF%E8%83%BD%E6%80%A7%E3%81%8C%E3%81%82%E3%82%8B%E3%81%9F%E3%82%81%E3%81%A7%E3%81%99%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E