SPRZ447E July   2017  – July 2024 AM5746 , AM5748 , AM5749

 

  1.   1
  2. 1Introduction
    1.     Related Documentation
    2.     Trademarks
    3.     Modules Impacted
  3. 2Silicon Advisories
    1.     Revisions SR 1.0 - Advisories List
    2.     i202
    3.     i378
    4.     i631
    5.     i694
    6.     i698
    7.     i699
    8.     i709
    9.     i727
    10.     i729
    11.     i734
    12.     i767
    13.     i782
    14.     i783
    15.     i802
    16.     i803
    17.     i807
    18.     i808
    19.     i809
    20.     i810
    21.     i813
    22.     i814
    23.     i815
    24.     i818
    25.     i819
    26.     i820
    27.     i824
    28.     i826
    29.     i829
    30.     i834
    31.     i849
    32.     i856
    33.     i862
    34.     i863
    35.     i869
    36.     i870
    37.     i871
    38.     i872
    39.     i874
    40.     i878
    41.     i879
    42.     i883
    43.     i889
    44.     i890
    45.     i893
    46.     i896
    47.     i897
    48.     i898
    49.     i899
    50.     i900
    51.     i903
    52.     i904
    53.     i916
    54.     i929
    55.     i930
    56.     i932
    57.     i933
    58.     i936
    59.     i940
    60.     i2446
  4. 3Silicon Limitations
    1.     Revisions SR 1.0 - Limitations List
    2.     i596
    3.     i641
    4.     i833
    5.     i838
    6.     i845
    7.     i848
    8.     i876
    9.     i877
    10.     i892
    11.     i909
    12.     i925
  5. 4Silicon Cautions
    1.     Revisions SR 1.0 - Cautions List
    2.     i827
    3.     i832
    4.     i836
    5.     i839
    6.     i864
    7.     i885
    8.     i886
    9.     i912
    10.     i926
    11.     i931
    12.     i935
    13.     i937
  6. 5Revision History

i2446

PRU-ICSS: Express bus initialization recommendation

Details:

The affected SoCs includes two instances of ICSS (ICSS1 and ICSS2). There is a bus connection from ICSS1 to ICSS2 and from ICSS2 to ICSS1. This bus logic requires a synchronous reset (clocks to be enabled) to drive a known state on its outputs. If clocks are not enabled to ICSS1 in software, then depending on the random state of the ICSS1 output bus, it may continuously issue Read or Write transactions to ICSS2 resulting in corruption of the ICSS2 module. The same situation can happen in reverse if ICSS1 is enabled and ICSS2 clocks are not on.

The power-up state of the critical control signals on each bus tends to settle to 0-state, but that is not guaranteed without a proper reset. This is why the issue may not be observed on all systems or may have different fail modes from system to system.

Workaround(s):

If a single ICSS module is used in a customer system, then clocks to the other ICSS module should be enabled first – this results in the ICSS module that is being used having proper deasserted state on the input bus before it is enabled.

If both ICSS modules are used in a system, then software can use the EDMA controller to issue an atomic write to the clock enable registers such that the two ICSS modules clocks are turned on within 20ns of each other.

Pseudo-code for a system that uses only ICSS2 or ICSS1 is shown here:

// CM_L4PER2_PRUSS1_CLKCTRL and CM_L4PER2_PRUSS2_CLKCTRL

/* Example #1 if ICSS2 used (ICSS1 not used) */

// Enable ICSS1 clock – ICSS1 state may be corrupted as ICSS2 is powered off now

*(volatile uint32_t*)(0x4A009718) = 0x00000002;

// Enable ICSS2

*(volatile uint32_t*)(0x4A009720) = 0x00000002;

/* Example #2 if ICSS1 usage (ICSS2 not used) */

// Enable ICSS2 clock – ICSS2 state may be corrupted as ICSS1 is powered off now

*(volatile uint32_t*)(0x4A009720) = 0x00000002;

// Enable ICSS1

*(volatile uint32_t*)(0x4A009718) = 0x00000002;

If a system uses both ICSS1 and ICSS2, contact your TI representative for an SDK patch that implements the EDMA workaround.