Keil Logo

Peripheral Simulation

For Infineon C515C-8R / -8E — SSC Interface

Simulation support for this peripheral or feature is comprised of:

  • Dialog boxes which display and allow you to change peripheral configuration.
  • VTREGs (Virtual Target Registers) which support I/O with the peripheral.

These simulation capabilities are described below.

SSC Interface Dialog

SSC Interface

The SSC Interface Dialog controls the Synchronous Serial Channel (SSC) unit of the C515C microcontroller. It supports half or full duplex operation. The application software can use this interface to interconnect with other microcontrollers in a master/slave architecture.

Control

  • SSCCON (SSC Control Register) contains the control flags that setup the SSC mode and baud rate.
  • SCEN (SSC System Enable) is set enable the SSC unit.
  • TEN (Slave Mode - Transmitter Enable) is set to allow the transmitter output to drive the STO output signal in Slave mode.
  • MSTR (Master Mode Selection) is set to configure this unit as the master unit. If reset, it is configured as a slave unit.
  • CPOL (Clock Polarity) is set to configure the shift clock's idle state to high. If reset, the clock's idle state is low.
  • CPHA (Clock Phase) is set to shift data out on the 1st clock edge, then sample data in on the second edge. It is reset to sample data in on the 1st edge, and shift data out on the second edge.
  • Baud Rate selects the oscillator frequency divisor used to generate the baud rate.
  • SSC Master Clock is the master clock output or slave clock input, depending on the setting of MSTR.

Status

  • SCF (SSC Status Register) contains the Write Collision Detect and Transfer Complete status values.
  • TC (Transfer Complete) is set when the last transfer of data completes. This bit is automatically reset when the SSC Status Register (SCF) is read.
  • WCOL (Write Collision Detect) is set an attempt is made to write to the transmit buffer (STB) before the previous data transfer completed. This bit is automatically reset when the SSC Status Register (SCF) is read.

Mode

  • SSCMOD (SSC Test Mode) contains the test mode controls. These modes are designed for factory testing and aren't used in normal operation.
  • LOOPB (Loopback Enable) is set to internally connect STO output to the SRI input through an inverter.
  • TRIO (Disable Tri-state Mode of SSC Inputs) is set to test the SSC in Slave mode by connecting the SSC inputs to the output latch of the corresponding port pin.
  • LSBSM (LSB Shift Mode) is set to shift data out of the SSC LSB first. It is reset to shift the data's MSB first.

Slave Select

  • SLS# (Slave Select Pin) is an active-low signal that controls data being shifted into or out of the SSC when is Slave mode.

Data

  • STB (SSC Transmit Buffer Register) contains the data to be transmitted.
  • SRB (SSC Receive Buffer Register) contains the data received from the last transfer.

SSCIN VTREG
Data Type: unsigned int

The SSCIN VTREG contains the SSC (Synchronous Serial Interface) input data received by the simulated MCU. Values you write to SSCIN are received immediately (in slave mode) or when the next byte is transmitted (in master mode). The following command causes the MCU to receive the byte 0x12:

SSCIN = 0x12

In slave mode, the SSCCLK VTREG must be set to the external slave mode input clock frequency. For example, the following debugger function may be used receive Synchronous Serial Interface data:

func void SSC_MCUIn (char b) {
  SSCCLK = 1000;   /* SSC Clock in Hz */
  SSCIN = b;
}

SSCLK VTREG
Data Type: unsigned long

The SSCCLK VTREG specifies the Synchronous Serial Interface frequency in hertz when operating in slave mode. For example:

SSCCLK = 100

sets the time for a 1-byte transfer to 0.01 seconds.

SSCOUT VTREG
Data Type: unsigned int

The SSCOUT VTREG contains the SSC (Synchronous Serial Interface) output data transmitted from the simulated MCU. The following debugger signal function outputs the HEX value of bytes transmitted using the Synchronous Serial Interface.

signal void SSC_MCUOut (void) {
  while (1) {
    wwatch(SSCOUT);
    printf ("SSC Output %2.2X\n", (unsigned) SSCOUT);
  }
}
Get more information about the
Peripheral Simulation Capabilities
of the µVision Debugger.
  Arm logo
Important information

This site uses cookies to store information on your computer. By continuing to use our site, you consent to our cookies.

Change Settings

Privacy Policy Update

Arm’s Privacy Policy has been updated. By continuing to use our site, you consent to Arm’s Privacy Policy. Please review our Privacy Policy to learn more about our collection, use and transfers
of your data.