beautypg.com

3 peripheral initializations – Texas Instruments TMS320TCI648x User Manual

Page 78

background image

www.ti.com

2.3.13.3

Peripheral Initializations

SRIO Functional Description

SRIO_REGS->SERDES_CFG0_CNTL = 0x00000013;

SRIO_REGS->SERDES_CFG1_CNTL = 0x00000000;

SRIO_REGS->SERDES_CFG2_CNTL = 0x00000000;

SRIO_REGS->SERDES_CFG3_CNTL = 0x00000000;

SRIO_REGS->SERDES_CFGRX0_CNTL

= 0x00081121 ;

// enable rx, half rate

SRIO_REGS->SERDES_CFGRX1_CNTL

= 0x00081121 ;

// enable rx, half rate

SRIO_REGS->SERDES_CFGRX2_CNTL

= 0x00081121 ;

// enable rx, half rate

SRIO_REGS->SERDES_CFGRX3_CNTL

= 0x00081121 ;

// enable rx, half rate

SRIO_REGS->SERDES_CFGTX0_CNTL

= 0x00010821 ;

// enable tx, half rate

SRIO_REGS->SERDES_CFGTX1_CNTL

= 0x00010821 ;

// enable tx, half rate

SRIO_REGS->SERDES_CFGTX2_CNTL

= 0x00010821 ;

// enable tx, half rate

SRIO_REGS->SERDES_CFGTX3_CNTL

= 0x00010821 ;

// enable tx, half rate

Set Device ID Registers

rdata = SRIO_REGS->DEVICEID_REG1;

wdata = 0x00ABBEEF;

mask

= 0x00FFFFFF;

mdata = (wdata & mask) | (rdata & ~mask);

SRIO_REGS->DEVICEID_REG1

= mdata ;

// id-16b=BEEF, id-08b=AB

rdata = SRIO_REGS->DEVICEID_REG2;

wdata = 0x00ABBEEF;

mask

= 0x00FFFFFF;

mdata = (wdata & mask) | (rdata & ~mask);

SRIO_REGS->DEVICEID_REG2

= mdata ;

// id-16b=BEEF, id-08b=AB

rdata = SRIO_REGS->PER_SET_CNTL;

data = 0x00000000;

mask

= 0x01000000;

mdata = (wdata & mask) | (rdata & ~mask);

SRIO_REGS->PER_SET_CNTL = mdata;

// bootcmpl=0

SRIO_REGS->DEV_ID

= 0xBEEF0030 ;

// id=BEEF, ti=0x0030

SRIO_REGS->DEV_INFO

= 0x00000000 ;

// 0

SRIO_REGS->ASBLY_ID

= 0x00000030 ;

// ti=0x0030

SRIO_REGS->ASBLY_INFO

= 0x00000000;

// 0x0000, next ext=0x0100

SRIO_REGS->PE_FEAT

= 0x20000019 ;

// proc, bu ext, 16-bit ID, 34-bit addr

SRIO_REGS->SRC_OP

= 0x0000FDF4;

// all

SRIO_REGS->DEST_OP

= 0x0000FC04;

// all except atomic

SRIO_REGS->PE_LL_CTL

= 0x00000001;

// 34-bit addr

SRIO_REGS->LCL_CFG_HBAR

= 0x00000000 ;

// 0

SRIO_REGS->LCL_CFG_BAR

= 0x00000000;

// 0

SRIO_REGS->BASE_ID

= 0x00ABBEEF;

// 16b-id=BEEF, 08b-id=AB

SRIO_REGS->HOST_BASE_ID_LOCK = 0x0000BEEF;

// id=BEEF, lock

SRIO_REGS->COMP_TAG

= 0x00000000;

// not touched

SRIO_REGS->SP_IP_DISCOVERY_TIMER = 0x90000000;// 0, short cycles for sim

SRIO_REGS->IP_PRESCAL

= 0x00000021;

// srv_clk prescalar=0x21 (333MHz)

SRIO_REGS->SP0_SILENCE_TIMER = 0x20000000;

SRIO_REGS->SP1_SILENCE_TIMER = 0x20000000;

SRIO_REGS->SP2_SILENCE_TIMER = 0x20000000;

SRIO_REGS->SP3_SILENCE_TIMER = 0x20000000;

rdata = SRIO_REGS->PER_SET_CNTL;

wdata = 0x01000000;

mask

= 0x01000000;

mdata = (wdata & mask) | (rdata & ~mask);

SRIO_REGS->PER_SET_CNTL = mdata;

// bootcmpl=1

RIO_REGS->SP_LT_CTL

= 0xFFFFFF00;

// long

78

Serial RapidIO (SRIO)

SPRUE13A – September 2006

Submit Documentation Feedback