Security register usage in FlexSPI peripheral in IMX RT1170

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

Security register usage in FlexSPI peripheral in IMX RT1170

1,114件の閲覧回数
anasnadukkandiyil
Contributor III

In IMXRT1170 FlexSPI peripheral, we are interfacing NOR flash W25Q512NW-DTR .We need to access the secure register for storing MAC address. Currently, we are using NOR flash driver adapted from SDK_2_10_0_EVKB-IMXRT1050. We are trying to create a lookup table for the commands 44h, 42h, 48h (Erase, Program, Read security registers). But the current NOR flash uses all the 64 slots except instruction indices 10 and 14. Is there any sample code or manual to do the same?

0 件の賞賛
返信
3 返答(返信)

1,092件の閲覧回数
anasnadukkandiyil
Contributor III

I added commands for Security register erase, read and  write as 10,12 and 14 indices respectively in the lookup table . Security register address 0x100 is used for read and write. The lookup table for these commands  are added as below.

config->lookupTable[4U * NOR_CMD_LUT_SEQ_IDX_SECURITY_ERASE] =
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_SDR, kFLEXSPI_1PAD, kSerialNorCmd_SecurityErase, kFLEXSPI_Command_RADDR_SDR,
kFLEXSPI_1PAD, address_bits);

config->lookupTable[NOR_CMD_LUT_SEQ_IDX_SECURITY_READ * 4U] =
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_SDR, kFLEXSPI_1PAD, kSerialNorCmd_ReadSecurityReg1, kFLEXSPI_Command_RADDR_SDR,
kFLEXSPI_1PAD, address_bits);
config->lookupTable[NOR_CMD_LUT_SEQ_IDX_SECURITY_READ * 4U + 1U] =
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_MODE8_SDR, kFLEXSPI_1PAD, mode_cycles, kFLEXSPI_Command_DUMMY_SDR,
kFLEXSPI_1PAD, 8);
config->lookupTable[NOR_CMD_LUT_SEQ_IDX_SECURITY_READ * 4U + 2U] =
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_READ_SDR, kFLEXSPI_1PAD, 0x04, 0, 0, 0);

 

config->lookupTable[4U * NOR_CMD_LUT_SEQ_IDX_SECURITY_PAGEPROGRAM] =
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_SDR, kFLEXSPI_1PAD, kSerialNorCmd_WriteSecurityReg1,
 kFLEXSPI_Command_RADDR_SDR, kFLEXSPI_1PAD, 32);
 config->lookupTable[4U * NOR_CMD_LUT_SEQ_IDX_SECURITY_PAGEPROGRAM + 1U] = FLEXSPI_LUT_SEQ(
 kFLEXSPI_Command_WRITE_SDR, kFLEXSPI_4PAD, 0x04, kFLEXSPI_Command_STOP, kFLEXSPI_1PAD, 0);

addr_bits value is configured to be 32. Added APIs for erase,program and read. But the value read is not correct as the expected value.

Is the above values correct for security registers?

0 件の賞賛
返信

1,088件の閲覧回数
jeremyzhou
NXP Employee
NXP Employee

Hi @anasnadukkandiyil ,
Thanks for your reply.
I was wondering if you can upload the complete demo code, further, whether you ever use the logic analyzer or oscilloscope to visualize the waves, if not, please give it a try.
Have a great day,
TIC

-------------------------------------------------------------------------------
Note:
- If this post answers your question, please click the "Mark Correct" button. Thank you!

 

- We are following threads for 7 weeks after the last post, later replies are ignored
Please open a new thread and refer to the closed one, if you have a related question at a later point in time.
------------------------------------------------------------------------------

0 件の賞賛
返信

1,103件の閲覧回数
jeremyzhou
NXP Employee
NXP Employee

Hi @anasnadukkandiyil ,
Thank you for your interest in NXP Semiconductor products and for the opportunity to serve you.
1) Is there any sample code or manual to do the same?
-- Please refer to flexspi_nor_polling_transfer demo to learn how to update the LUT.
TIC

-------------------------------------------------------------------------------
Note:
- If this post answers your question, please click the "Mark Correct" button. Thank you!

 

- We are following threads for 7 weeks after the last post, later replies are ignored
Please open a new thread and refer to the closed one, if you have a related question at a later point in time.
-------------------------------------------------------------------------------

0 件の賞賛
返信