Flexbus write cycle

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

Flexbus write cycle

Jump to solution
2,767 Views
martindusek
Contributor V

Hi,

I have 16-bit SRAM connected to K22 via Flexbus. Port size of Flexbus is set to 16-bit. No delays are introduced in write/read cycles (I mean WS/ASET/RDAH/WRAH re all set to 0). This is my configuration:

FB->CS[0].CSCR = FB_CSCR_PS(2)
| FB_CSCR_BLS_MASK
| FB_CSCR_ASET(0x0)
| FB_CSCR_RDAH(0x0)
| FB_CSCR_WRAH(0x0)
| FB_CSCR_AA_MASK
| FB_CSCR_WS(0x0)
;

I write 32 bit integer into my memory:

volatile int *sram;
sram = SRAM_START_ADDRESS;

sram[0] = 0;

I can see that writing first part of my 32 bit integer takes only 3 flexbus clock cycles. (in the picture you can see three 32 bit integer writes to the 16 bit memory)

3c.jpg

In all documents I read flexbus read/write cycles take 4 clock cycles min. Can you please help me in understanding this 3 clock cycle write?

Labels (1)
0 Kudos
Reply
1 Solution
2,373 Views
Hui_Ma
NXP TechSupport
NXP TechSupport

Hi Martin,

I got the feedback from Kinetis product team with below feedback:

In this case, a 32-bit access is launched on a 16-bit port, that means there would definitely be two continuous accesses here. 

In fact, S3 is used to terminate the transfer, so in this case, it is reasonable that the 1st access skipped S3 and goes to S0 directly, so it only take 3 clocks here.

But in the second access(it is writing here),  S3 is a must to terminate the transfer.

We have a Flexbus timing about read from 8-bit port size device and write to 16-bit port device with 32-bit access (WS/ASET/RDAH/WRAH re all set to 0).

Please check attached picture for detailed info.

I zoom in the 32-bit write to 16-bit port device and get there take 7 Flexbus clock cycles, the first 16-bit write take 3 Flexbus clock cycles:

pastedImage_2.png

Wish it helps.


Have a great day,
Mike

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

View solution in original post

7 Replies
2,373 Views
Hui_Ma
NXP TechSupport
NXP TechSupport

Hi,

From the scope picture, the write operation with 3 Flexbus cycles.

Could you provide the more detailed Flexbus setting?

What's the SRAM_START_ADDRESS value?

What's the Flexbus clock frequency?

If possible, could you provide Flexbus initialization code?

Thank you.


Have a great day,
Mike

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

0 Kudos
Reply
2,373 Views
martindusek
Contributor V

Hi Mike,

my initialization code (I do not post pin function initialization):

#define RAM_START_ADDRESS 0x18000000

void FlexBusInit() {
SIM->SCGC7 |= SIM_SCGC7_FLEXBUS_MASK;
FB->CSPMCR = FB_CSPMCR_GROUP1(2);

FB->CS[0].CSAR = RAM_START_ADDRESS;

FB->CS[0].CSCR = FB_CSCR_PS(2)
| FB_CSCR_BLS_MASK
| FB_CSCR_ASET(0x0)
| FB_CSCR_RDAH(0x0)
| FB_CSCR_WRAH(0x0)
| FB_CSCR_AA_MASK
| FB_CSCR_WS(0x0);

FB->CS[0].CSMR = FB_CSMR_BAM(0x7) | FB_CSMR_V_MASK;
}

Flexbus clock is 30 MHz, can bee seen on the scope printscreen.

0 Kudos
Reply
2,373 Views
Hui_Ma
NXP TechSupport
NXP TechSupport

Hi

From the Flexbus initialization code, there without any issue.

Could you post the Flebux registers value after initialization?

Please make sure there doesn't enable the burst write.

When you do a 16-bit operation, the Flexbus write operation will be 4 cycles?

Thanks.

best regards,

Mike

0 Kudos
Reply
2,373 Views
martindusek
Contributor V

Hi,

when I perform 16 bit write on 120 MHz CPU frequency:

volatile short *flex = SRAM_START_ADDRESS;


while(1) {
flex[0] = 5;
}

I can see 4 flexbus clock cycles between every FB_TS assertion on my scope so I guess I can confirm that 16 bit write cycle takes 4 flexbus cycles.

Flexbus registers after initialization:

CSAR0 = 0x18000000

CSMR0 = 0x00070001

CSCR0 = 0x00000380

CSPMCR = 0x20000000

0 Kudos
Reply
2,373 Views
Hui_Ma
NXP TechSupport
NXP TechSupport

Hi,

Thank you for the test.

I need to check with Kinetis product team about why the 32-bit write to 16-bit port, the first write operation with only 3 Flexbus clock cycles.

I will let you know when there with any feedback.

Thank you for the patience.


Have a great day,
Mike

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

0 Kudos
Reply
2,373 Views
martindusek
Contributor V

Hi Mike,

great, thank you very much. waiting for your reply.

Martin

0 Kudos
Reply
2,374 Views
Hui_Ma
NXP TechSupport
NXP TechSupport

Hi Martin,

I got the feedback from Kinetis product team with below feedback:

In this case, a 32-bit access is launched on a 16-bit port, that means there would definitely be two continuous accesses here. 

In fact, S3 is used to terminate the transfer, so in this case, it is reasonable that the 1st access skipped S3 and goes to S0 directly, so it only take 3 clocks here.

But in the second access(it is writing here),  S3 is a must to terminate the transfer.

We have a Flexbus timing about read from 8-bit port size device and write to 16-bit port device with 32-bit access (WS/ASET/RDAH/WRAH re all set to 0).

Please check attached picture for detailed info.

I zoom in the 32-bit write to 16-bit port device and get there take 7 Flexbus clock cycles, the first 16-bit write take 3 Flexbus clock cycles:

pastedImage_2.png

Wish it helps.


Have a great day,
Mike

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