Using NVM chip on MPC5775B EVB

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

Using NVM chip on MPC5775B EVB

6,902 Views
sonik82
Contributor III

I would like to use NVM chip (M95M01-DWMN3TP/K) on DVCU5775EVM, so initially I have prepared simple model just to check chip status.

Chip is connected to SPI0 with CS1

nvm_1.PNGnvm_2.PNG

And I have used these settings for SPI blocks

nvm_5.PNG

nvm_6.PNG

Then have prepared stateflow diagram to send control commands

nvm_3.PNG

where Tx_data is control command (RDSR) from M95M01 datasheet

sonik82_0-1624177375228.png

and this command goes after chip is selected

sonik82_1-1624177630426.png

Finally I have got following model.

nvm_4.PNG

After flashing, I have used Freemaster to check SPI feedback signal from NVM and it is always 0xff.

nvm_7.PNG

Tags (1)
0 Kudos
Reply
13 Replies

5,944 Views
oguz
Contributor I

Hi,

 I am dealing with the same problem but couldn't find the solution. Can you help me with that??

0 Kudos
Reply

6,862 Views
Baris
Contributor II

Dear @mariuslucianand and @sonik82 

I faced the same problem and I want to save any data in EEPROM, can you help with that?

0 Kudos
Reply

6,884 Views
mariuslucianand
NXP Employee
NXP Employee

Hello @sonik82 ,

I had a look at your model and attached the model with a couple of changes. I don't have access to your board and I cannot test it, but I had a look at the signals using the logic analyzer. See the image attached below.

mariuslucianand_0-1624349389909.png

 

1.  SPI settings - for that you can select the CS pin in the SPI_Config, you don't need to change it by hand. To select the device you can select the CS in the Master transmit block, the one you have already used.

mariuslucianand_1-1624349845093.png

mariuslucianand_2-1624350277160.png

2. In the Stateflow, you can remove the chip select state, because the DSPI will handle that, so you can only send and decode the responses from the SPI. 

mariuslucianand_3-1624350367033.png

Hope this helps,

Marius

 

 

 

 

0 Kudos
Reply

6,851 Views
sonik82
Contributor III

@mariuslucianand 

As per datasheet, we need to keep Chip select low while sending command and getting data from chip

sonik82_2-1624568581644.png

Your image shows that Chip Select goes High after transmitting of command, am I right?

sonik82_0-1624568237232.png

Is it possible to keep this signal Low until we will get data?

 

Another question, these SPI settings are correct 

sonik82_3-1624568942974.png

to provide one of following SPI modes?

sonik82_4-1624569019113.png

Also, to send 8 bits command and 24 bits address I need to change SPI frame size to 32, am I right? Then how to change this frame size dynamically? For example to Read Status Register it is required only 8 bits, to Read data 8 bits for command + 24 bits for address, to Write data 8 bits for command + 24 bits for address + Data.

Input and Output ports have same size, so does it mean that we can only send/get SPI frames with same size?

sonik82_0-1624570247904.png

 

  

 

 

0 Kudos
Reply

6,829 Views
sonik82
Contributor III

I have changed SPI frame size from 8 to 16 bits, assuming that Chip select will be Low enough time to read feedback (8 bits) from NVM chip.

sonik82_0-1624604328698.png

 

Now my SPI receive data is 0. 

sonik82_0-1624603960892.png

It looks fine for Read Status Register command, because bits 0,1,2,3,7 should not be set by default.

sonik82_1-1624604560300.png

I am going to check Read/Write commands.

 

0 Kudos
Reply

6,825 Views
sonik82
Contributor III

@mariuslucianand 

I guess if I set SPI frame size to 24 bits then in case when my command is 8 bits, expected response also 8 bit, then I will get next 8 bits as 0xFF, am I right?

0 Kudos
Reply

6,826 Views
sonik82
Contributor III

I guess if I set SPI frame size to 24 bits then in case when my command is 8 bits, expected response also 8 bit, then I will get next 8 bits as 0xFF, am I right?

0 Kudos
Reply

6,817 Views
mariuslucianand
NXP Employee
NXP Employee

Hello @sonik82 ,

You can send variable bytes number (8, 16, 24, 32, 40 ...) with a continuous CS by selecting the Continuous transfer. But I've seen that you have already done that. 

mariuslucianand_0-1624607963579.png

So, you select the frame size as 8, and you populate an array with the commands you want to send. F4irst byte is the command, then the next 3 bytes are the address. If you provide such an array to the SPI Send block, this will output on bus 4 continuous bytes, with only one chip select transition.

Hope this helps,

Marius

 

0 Kudos
Reply

6,809 Views
sonik82
Contributor III

@mariuslucianand SPI chip selection remains Low only when I am sending data to chip or it remains selected while receiving data from SPI also?

0 Kudos
Reply

6,803 Views
mariuslucianand
NXP Employee
NXP Employee

Hello @sonik82 ,

I think it will remain low as long as you transmit. But, if you expect to receive for example 4 bytes from the NVM chip, you can compute the array like this: [cmd, addr, addr, add, 0xFF, 0xFF, 0xFF, 0xFF] basically you send an 0xFF or 0x00 as long as you want to receive from the NVM chip. Please give this a try.

Marius

0 Kudos
Reply

6,770 Views
sonik82
Contributor III

Hello @mariuslucianand 

I have checked your idea. To do it, I have modified model by creation of 4 commands: 

RDSR (Read Status Register) [ 00000101 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF] 

sonik82_4-1624729396494.png

WREN (Write Enable) [ 00000110 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF]  because of

sonik82_2-1624729251596.png

WRITE (Write to Memory Array) [ 00000010 0x00 0x00 0x00 11000100 0xFF]

READ (Read from Memory Array) [ 00000011 0x00 0x00 0x00 0xFF 0xFF]

sonik82_5-1624729497228.png

When I use SPI frame size, received data is always 0xFF.

sonik82_0-1624728449115.png

Same situation with SPI frame size 16, but with using size 24 output data becomes 0x00

sonik82_3-1624729313095.png

 

0 Kudos
Reply

6,858 Views
sonik82
Contributor III

@mariuslucianand  Thank you for model modification, but, unfortunately, I am still facing same issue SPI receive signal is always 0xFF and it does not matter which command I send to NVM.

 

6,247 Views
ranulf
Contributor IV

@sonik82Sonic82, have you had any success yet in using the NVM chip on the MPC5775BEVB? I have tried also, with no success-so far.