Special Filter Instructions

After the FIR or COR instruction executes, the new startOfBuff will be the last location in the circular buffer. After another FIR/COR instruction, the new startOfBuff will be the second to last location in the circular buffer, and so on.

The second detail is the STAT register. The STAT register must be saved im- mediately after every FIR or COR instruction. Consequently, this saved value must be loaded before every FIR or COR instruction. If the tag bit in the STAT register is set before an FIR or COR instruction, this tells the processor two things. First, it knows that it must wrap around to the first RAM location of the circular buffer. Second, it knows that the startOfBuff (and R0) currently points to the last location in the circular buffer. Thus, R0 will increment by R5 after the first multiply. This will become more clear after examining the next ex- ample code.

The third detail is that the filter coefficients take up only N RAM locations, but the circular buffer takes up N+1 RAM locations.

Below is an example of the FIR or COR execution inside a DAC interrupt ser- vice routine.

;FIR Filtering routine (N = 3)

±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±

rovm

 

;reset overflow mode

mov

R5, ±2 * N

;circular buffer length (3 words)

mov

R1,coeffs

;R1 points to first of N filter

 

 

coefficients

mov

MR,*R1++

;must increment R1

mov

R0,*startOfBuff

;R0 points to start of circular

 

 

buffer

mov

AP0,0

;set up room for the

mov

STR,0

; 32 bit output sample (AC0

 

 

and AC1)

zacs

A0

; STR should be 1 for COR/CORK

 

 

instructions

mov

STAT,*filterSTAT_tag

;load STAT with last filter

 

 

 

tag status

rpt

N±2

 

 

fir

A0,*R0++

;Do one sample ±±> 32 bit result

mov

*filterSTAT_tag,STAT

;save STAT with last filter

 

 

 

tag status

 

 

;R0 now points to the last/oldest

 

 

sample

movs

*ySampleOut,A0

;FIR outputs bits 0±15 in AC0,

 

 

16±32 in AC1

4-62

Page 154
Image 154
Texas Instruments MSP50C614 manual STR,0

MSP50C614 specifications

The Texas Instruments MSP50C614 is a microcontroller that belongs to the MSP430 family, renowned for its low power consumption and versatile functionality. Primarily designed for embedded applications, this microcontroller is favored in various industries, including consumer electronics, industrial automation, and healthcare devices.

One of the standout features of the MSP50C614 is its ultra-low power technology, which enables it to operate in various power modes. This makes it ideal for battery-powered applications, where energy efficiency is crucial. The MSP430 architecture allows for a flexible power management system, ensuring that energy is conserved while providing robust performance.

The MSP50C614 is equipped with a 16-bit RISC CPU that delivers high performance while maintaining low power usage. With a maximum clock frequency of 16 MHz, it can execute most instructions in a single cycle, resulting in swift operation and responsive performance. This microcontroller also comes with a generous flash memory capacity, allowing developers to store large amounts of code and data conveniently.

In terms of peripherals, the MSP50C614 is highly versatile. It features a range of digital and analog input/output options, including multiple timers, GPIO ports, and various communication interfaces like UART, SPI, and I2C. This extensive set of peripherals allows for seamless integration with other components and simplifies the design of complex systems.

The integrated 12-bit Analog-to-Digital Converter (ADC) stands out as a valuable characteristic of the MSP50C614. This feature enables the microcontroller to convert physical analog signals into digital data, making it particularly useful for sensing applications and real-time monitoring.

Another noteworthy technology employed in the MSP50C614 is its support for low-voltage operations. With a broad supply voltage range, this microcontroller can function efficiently in diverse environments and is suitable for low-power applications, enhancing its practicality.

Moreover, Texas Instruments provides software support in the form of Code Composer Studio and various libraries that make it easier for developers to program and utilize the MSP50C614 effectively.

In summary, the Texas Instruments MSP50C614 microcontroller is a powerful, low-power solution equipped with the features and technologies necessary for efficient operation in a wide array of applications. Its blend of performance, flexibility, and energy efficiency makes it a popular choice among engineers and designers looking to create innovative, sustainable designs in the rapidly evolving tech landscape.