Jonathan W. Valvano

(5) **Question 1.** What is dropout voltage of a linear regulator?

C) A linear regulator produces a constant output voltage under conditions of variable current. In order to operate properly, a linear regulator needs an input voltage greater than or equal to the output voltage plus a fixed constant. (fixed constant is the dropout voltage)

(25) **Question 2.** The goal is to transmit synchronous serial data

(10) **Part a)** Show the initialization code that configures PD2, PD1, and PD0. Be friendly.

```c
void SS_Init(void){ volatile unsigned long delay;
    SYSCTL_RCGC2_R |= 0x00000008; // activate port D
    delay = SYSCTL_RCGC2_R;
    GPIO_PORTD_DIR_R |= 0x07;  // PD2, PD1, PD0 outputs
    GPIO_PORTD_DEN_R |= 0x07;  // enable digital I/O on PD2, PD1, PD0
    PD2 = 0;
    PD0 = 1;
}
```

(15) **Part c)** Show the function that outputs one byte to the PD2-PD0 pins.

```c
void SS_Output(unsigned char data){
    PD0 = 0;            // frame select low
    for(i=0;i<8;i++){   // bit 7
        PD1 = data>>6;    // bit 1 is high or low depending on bit 7
        PD2 = 4;          // clock high
        data = data << 1; // shift next bit into bit 7 position
        PD2 = 0;          // clock low
    }
    PD0 = 1;            // frame select high
}
```

```c
void SS_Output(unsigned char data){  // faster
    PD0 = 0;            // frame select low
    // bit 7
    PD1 = data>>6;      // bit 1 is high or low depending on bit 7
    PD2 = 4;            // clock high
    PD2 = 0;            // clock low
    // bit 6
    PD1 = data>>5;      // bit 1 is high or low depending on bit 6
    PD2 = 4;            // clock high
    PD2 = 0;            // clock low
    // bit 5
    PD1 = data>>4;      // bit 1 is high or low depending on bit 5
    PD2 = 4;            // clock high
    PD2 = 0;            // clock low
    // bit 4
    PD1 = data>>3;      // bit 1 is high or low depending on bit 4
    PD2 = 4;            // clock high
    PD2 = 0;            // clock low
    // bit 3
    PD1 = data>>2;      // bit 1 is high or low depending on bit 3
```
PD2 = 4;            // clock high
PD2 = 0;            // clock low
// bit 2
PD1 = data>>1;      // bit 1 is high or low depending on bit 2
PD2 = 4;            // clock high
PD2 = 0;            // clock low
// bit 1
PD1 = data;         // bit 1 is high or low depending on bit 1
PD2 = 4;            // clock high
PD2 = 0;            // clock low
// bit 0
PD1 = data<<1;      // bit 1 is high or low depending on bit 0
PD2 = 4;            // clock high
PD2 = 0;            // clock low
PD0 = 1;            // frame select high

(10) Question 3. You are building a quantitative data acquisition system that measures voltage.
Part a) Gain is used to match the range of the input to the ADC range. Gain = 3V/100mV = 30.
Part b) We must pass the signals of interest 0 to 200 Hz. We must reject signals above 2kHz to prevent
aliasing.
Part c) The maximum allowable voltage noise is the resolution referred to the input, 100 μV.

(5) Question 4. As applied to EE445L labs 5 and 9, how are resolution and accuracy related?
D) Accuracy depends on resolution in addition to calibration drift.

(10) Question 5. 2π is about 6434/1024 (2π is about 6.283203125)
    C = (6434*R)>>10; // circumference is 2pi times radius)

(20) Question 6. Design an analog circuit with the following transfer function \( V_{out} = 25*(V_{in}+0.05) \). The
input is a single voltage (not differential). The input range is -0.05 to 0.05 V and the output range is 0 to
2.5V. Use an analog reference and one rail to rail op amp (not an instrumentation amp). Show your work
and label all chip numbers and resistor values, including R1 and R2. You do not have to show pin numbers.
\[
V_{out} = 25*(V_{in}+0.05).
\]
Create a 1.25 V reference with LM4041
\[
V_{z} = 1.233 (1+R2/R1), \hspace{1cm} (1.233 is the fixed voltage of the zener)
\]
\[
1.25 = 1.233(1+R2/R1), R2/R1= 0.017, R2=1k\Omega, and R1=58.8k\Omega
\]
\[
V_{out} = 25*V_{in}+ 1.25
\]
Add ground gain of -25 to make all gains sum to 1
\[
V_{out} = 25*V_{in} + V_{ref} - 25*V_{g}
\]
Choose \( R_f \) to be common multiple of 1, 25 \( R_f = 250k\Omega \),
Choose other resistors to create needed gains, \( R_{in}=10k\Omega, R_{ref}=250k\Omega, R_g=10k\Omega \)
(25) **Question 7.** The goal is to toggle the output PD0 every time there is a rising edge of PD1 input.

(10) **Part a)** Show the initialization code that configures PD1 and PD0.

```c
void PORTD_Init(void){
    volatile unsigned long delay;
    SYSCTL_RCGC2_R |= 0x00000008; // activate port D
    delay = SYSCTL_RCGC2_R;
    GPIO_PORTD_DIR_R |= 0x01; // PD1 output, PD1 input
    GPIO_PORTD_DEN_R |= 0x03; // enable digital I/O on PD1, PD0
    GPIO_PORTD_IS_R &= ~0x02; // edge
    GPIO_PORTD_IBE_R &= ~0x02; // not both
    GPIO_PORTD_IEV_R |= 0x02; // rise
    GPIO_PORTD_IM_R |= 0x02; // arm
    NVIC_PRI0_R = (NVIC_PRI0_R&0x00FFFFFF)|0x00000000;
    NVIC_EN0_R |= 8; // enable
    EnableInterrupts();
}
```

(15) **Part b)** Show the edge-triggered interrupt service routine.

```c
void GPIOPortD_Handler(void){
    GPIO_PORTD_ICR_R = 0x02; // acknowledge flag1
    PD0 ^= 0x01; // toggle PD0
}
```