Keil Logo

Peripheral Simulation

For Hynix Semiconductor GMS97C2051 — Analog Comparator

Simulation support for this peripheral or feature is comprised of:

  • Accurate simulation of special on-chip features.
  • 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.

Analog Comparator

The AT89C1051, AT89C2051 and AT89C4051 MCUs support an on-chip Analog Comparator. This comparator uses AIN0 (P1.0) and AIN1 (P1.1) input pins for analog input and uses bit 6 of Port 3 (P3.6) for the comparator output result. Because of this, P3.6 is not available for general purpose I/O. The MCU sets the comparator output (P3.6) to 1 when the analog input AIN0 (P1.0) is greater than or equal to the analog input AIN1 (P1.1).

Port 3 Dialog

Port 3

This dialog displays the SFR and pins of Port 3.

  • P3: This is the P3 SFR. The HEX value and value of each bit is displayed and may be changed from this dialog.
  • Pins: These are the states of the pins on the simulated MCU. When used as outputs, these have the same value as the P3 SFR. When used as inputs (P3.x is 1) you may set the level of the input pin to high (1) or low (0). P3.6 may not be used for general purpose I/O. It is internally connected to the Analog Comparator output.

The PORT3 VTREG may be used (from the Command Window or from a user or signal function) to affect the input values of the simulated pins of Port 3.

AINx VTREG
Data Type: float

The AINx VTREGs set the analog input voltages for simulated A/D converters. The AINx VTREGs represent the inputs to the analog input pins of the MCU for analog input 0, 1, 2, and so on. AIN0 sets the input voltage for analog input #0, AIN1 sets the input voltage for analog input #1, etc. If you have properly configured the analog inputs, the following commands (typed in the debugger's Command Window) input the voltages specified.

AIN0 = 0.000  /* Analog Input 0 = 0.000 volts */
AIN1 = 2.500  /* Analog Input 1 = 2.500 volts */
AIN2 = 4.999  /* Analog Input 2 = 4.999 volts */

You may create a debugger signal function to periodically change the value of the A/D input. The following signal function increases the A/D Channel 1 input voltage by 0.1 volts each second.

signal void AIN1_sig (void) {
float f;

for (f = 0.0; f < 5.0; f += 0.1)
  {
  swatch (1.0);                  // Delay 1 second
  AIN1 = f;                      // Set AIN1 Voltage
  }
}
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.