TI MSP430: Difference between revisions
EleanorRugby (talk | contribs) Turn the first occurrence of Code Composer Studio into a link to the corresponding Wikipedia article |
|||
Line 407: | Line 407: | ||
Texas Instruments provides software development tools directly, and in conjunction with partners. One such toolchain is the [[IAR Systems|IAR]] C/C++ compiler and IDE. A Kickstart edition can be downloaded for free from TI or IAR; it is limited to 8KB of C/C++ code in the compiler and debugger (assembly language programs of any size can be developed and debugged with this free toolchain). |
Texas Instruments provides software development tools directly, and in conjunction with partners. One such toolchain is the [[IAR Systems|IAR]] C/C++ compiler and IDE. A Kickstart edition can be downloaded for free from TI or IAR; it is limited to 8KB of C/C++ code in the compiler and debugger (assembly language programs of any size can be developed and debugged with this free toolchain). |
||
TI also combines a version of its own compiler and tools with its Eclipse-based |
TI also combines a version of its own compiler and tools with its Eclipse-based [[Code Composer Studio]] [[Integrated development environment|IDE]] ("CCS"). It sells full-featured versions, and offers a free version for download which has a code size limit of 16KB. CCS supports in-circuit emulators, and includes a simulator and other tools; it can also work with other processors sold by TI. |
||
The open source community produces a freely available software development toolset ([http://mspgcc.sourceforge.net/ MSPGCC]) based on old versions the [[GNU toolchain|GNU toolset]], but there is little effort to update it to current versions. Perhaps in part because of that lack of effort, the object code size and speed are not as optimal as the results from a commercial compiler.{{Fact|date=February 2007}} There is very early [http://lists.ransford.org/pipermail/llvm-msp430/ llvm-msp430] project, which may eventually provide better support for MSP430 in [[LLVM]]. |
The open source community produces a freely available software development toolset ([http://mspgcc.sourceforge.net/ MSPGCC]) based on old versions the [[GNU toolchain|GNU toolset]], but there is little effort to update it to current versions. Perhaps in part because of that lack of effort, the object code size and speed are not as optimal as the results from a commercial compiler.{{Fact|date=February 2007}} There is very early [http://lists.ransford.org/pipermail/llvm-msp430/ llvm-msp430] project, which may eventually provide better support for MSP430 in [[LLVM]]. |
Revision as of 18:06, 28 October 2009
The MSP430 is a microcontroller family from Texas Instruments. Built around a 16-bit CPU, the MSP430 is designed for low cost, low power consumption embedded applications. The architecture is reminiscent of the DEC PDP-11.The MSP430 is particularly well suited for metering, wireless RF, or battery-powered applications.
The MSP430 is a popular choice for low powered embedded devices. The current drawn in idle mode can be less than 1 microamp. The top CPU speed is 25 MHz. It can be throttled back for lower power consumption. The MSP430 also utilizes six different Low-Power Modes, which can disable unneeded clocks and CPU. This allows the MSP430 to sleep, while its peripherals continue to work without the need for an energy hungry processor. Additionally, the MSP430 is capable of wake-up times below 1 microsecond, allowing the microcontroller to stay in sleep mode longer, minimizing its average current consumption. Note that MHz is not equivalent to MIPS, and different architectures can obtain different MIPS rates at lower CPU clock frequencies, which can result in lower dynamic power consumption for an equivalent amount of processing.
The device comes in a variety of configurations featuring the usual peripherals: internal oscillator, timer including PWM, watchdog, USART, SPI, I2C, 10/12/14/16-bit ADCs, and brownout reset circuitry. Some less usual peripheral options include comparators (that can be used with the timers to do simple ADC), on-chip op-amps for signal conditioning, 12-bit DAC, LCD driver, hardware multiplier, USB, and DMA for ADC results. Apart from some older EPROM (PMS430E3xx) and high volume mask ROM (MSP430Cxxx) versions, all of the devices are in-system programmable via JTAG or a built in bootstrap loader (BSL) using RS-232.
There are, however, limitations that prevent it from being used in more complex embedded systems. The MSP430 does not have an external memory bus, so is limited to on-chip memory (up to 256 KB Flash and 16 KB RAM) which might be too small for applications that require large buffers or data tables.
MSP430 generations
There are five general generations of MSP430 processors. In order of development, they were the '3xx generation, the '1xx generation, the '4xx generation, the '2xx generation, and the '5xx generation. The digit after the generation identifies the model (generally higher model numbers are larger and more capable), the third digit identifies the amount of memory on board, and the fourth, if present, identifies a minor model variant. The most common variation is a different on-chip analog-to-digital converter.
MSP430x1xx Series
The MSP430x1xx Series is the basic generation without an embedded LCD controller. They are generally smaller than the '3xx generation. These Flash or ROM based Ultra-Low Power MCUs offer 8 MIPS, 1.8-3.6V operation, up to 60 KB Flash, and a wide range of high-performance analog and intelligent digital peripherals.
- Power specs - As low as
- 0.1 μA RAM retention
- 0.7 μA real-time clock mode
- 200 μA / MIPS active
- Feature Fast Wake-Up From Standby Mode in <6 μs
- Power specs - As low as
- Device Parameters
- Flash Options: 1 KB – 60 KB
- ROM Options: 1 KB – 16 KB
- RAM Options: 512 B – 10 KB
- GPIO Options: 14, 22, 48 pins
- ADC Options: Slope, 10 & 12-bit SAR
- Other Integrated peripherals: Analog Comparator, DMA, Hardware Multiplier, SVS, 12-bit DAC
- Device Parameters
MSP430F2xx Series
The MSP430F2xx Series are similar to the '1xx generation, but operate at even lower power, support up to 16 MHz operation, and have a more accurate (+/-2%) on-chip clock that makes it easier to operate without an external crystal. These Flash-based Ultra-Low Power offer 1.8V-3.6V operation. Includes the Very-Low power Oscillator (VLO), internal pull-up/pull-down resistors, and low-pin count options.
- Power Specs Overview, as low as:
- 0.1 μA RAM retention
- 0.3 μA Standby mode (VLO)
- 0.7 μA real-time clock mode
- 220 μA / MIPS active
- Feature Ultra-Fast Wake-Up From Standby Mode in <1 μs
- Power Specs Overview, as low as:
- Device Parameters
- Flash Options: 1 KB – 120 KB
- RAM Options: 128 B – 8 KB
- GPIO Options: 10, 16, 24, 32, 48, 64 pins
- ADC Options: Slope, 10 & 12-bit SAR, 16-bit Sigma Delta
- Other Integrated peripherals: Analog Comparator, Hardware Multiplier, DMA, SVS, 12-bit DAC, Op Amps
- Device Parameters
MSP430x3xx Series
The MSP430x3xx Series is oldest generation, designed for portable instrumentation with an embedded LCD controller. This also includes a frequency-locked loop oscillator that can automatically synchronize to a low-speed (32 kHz) crystal. This generation does not support EEPROM memory, only mask ROM and UV-eraseable and one-time programmable EPROM. Later generations provide only flash ROM and mask ROM options. These devices offer 2.5 – 5.5 V operation, up to 32 KB ROM.
- Power Specs Overview, as low as:
- 0.1 μA RAM retention
- 0.9 μA real-time clock mode
- 160 μA / MIPS active
- Feature Fast Wake-Up From Standby Mode in <6 μs
- Power Specs Overview, as low as:
- Device Parameters
- ROM Options: 2KB – 32 KB
- RAM Options: 512 B – 1 KB
- GPIO Options: 14, 40 pins
- ADC Options: Slope, 14-bit SAR
- Other Integrated peripherals: LCD controller, Hardware Multiplier
- Device Parameters
MSP430x4xx Series
The MSP430x4xx Series are similar to the '3xx generation, and also include an integrated LCD controller, but are larger and more capable. These Flash or ROM based devices offers 8-16 MIPS at 1.8V-3.6V operation, with FLL, and SVS. Ideal for low power metering and medical applications.
- Power Specs Overview, as low as:
- 0.1 μA RAM retention
- 0.7 μA real-time clock mode
- 200 μA / MIPS active
- Feature Fast Wake-Up From Standby Mode in <6 μs
- Power Specs Overview, as low as:
- Device Parameters
- Flash/ROM Options: 4kB – 120 KB
- RAM Options: 256 B – 8 KB
- GPIO Options: 14, 32, 48, 56, 68, 72, 80 pins
- ADC Options: Slope, 10 &12-bit SAR, 16-bit Sigma Delta
- Other Integrated peripherals: LCD Controller, Analog Comparator, 12-bit DAC, DMA, Hardware Multiplier, Op Amp, USCI Modules
- Device Parameters
MSP430x5xx Series
The MSP430x5xx Series are able to run up to 25 MHz, have up to 256 kB flash memory and up to 16 kB RAM. This new Flash-based family features the lowest active power consumption with up to 25 MIPS at 1.8V-3.6V operation (165 uA/MIPS). Includes an innovative Power Management Module for optimal power consumption. Many devices feature integrated USB.
- Power Specs Overview, as low as:
- 0.1 μA RAM retention
- 2.5 μA real-time clock mode
- 165 μA / MIPS active
- Feature Fast Wake-Up From Standby Mode in <5 μs
- Power Specs Overview, as low as:
- Device Parameters:
- Flash Options: up to 256 KB
- RAM Options: up to 16 KB
- ADC Options: 10 & 12-bit SAR
- Other Integrated peripherals: USB, Analog Comparator, DMA, Hardware Multiplier, RTC, USCI, 12-bit DAC
- Device Parameters:
Note that when the flash size is over 64K words (128 KBytes), instruction addresses can no longer be encoded in just two bytes. This change in pointer size causes some incompatibilities with previous parts.
MSP430 CPU
The MSP430 CPU uses a von Neumann architecture, with a single address space for instructions and data. Memory is byte-addressed, and pairs of bytes are combined little-endian to make 16-bit words.
The processor contains 16 16-bit registers.[1] R0 is the program counter, R1 is the stack pointer, R2 is the status register, and R3 is a special register called the constant generator, providing access to 6 commonly used constant values without requiring an additional operand. R4 through R15 are available for general use.
The instruction set is very simple; there are 27 instructions in three families. Most instructions are available in 8-bit (byte) and 16-bit (word) versions, depending on the value of a B/W bit - the bit is set to 1 for 8-bit and 0 for 16-bit. Byte operations to memory affect only the addressed byte, while byte operations to registers clear the most significant byte.
15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Instruction |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 0 | 0 | 1 | 0 | 0 | opcode | B/W | As | register | Single-operand arithmetic | ||||||
0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | B/W | As | register | RRC Rotate right through carry | ||||
0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | As | register | SWPB Swap bytes | ||||
0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | B/W | As | register | RRA Rotate right arithmetic | ||||
0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | As | register | SXT Sign extend byte to word | ||||
0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | B/W | As | register | PUSH Push value onto stack | ||||
0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | As | register | CALL Subroutine call; push PC and move source to PC | ||||
0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | RETI Return from interrupt; pop SR then pop PC |
0 | 0 | 1 | condition | 10-bit signed offset | Conditional jump; PC = PC + 2×offset | |||||||||||
0 | 0 | 1 | 0 | 0 | 0 | 10-bit signed offset | JNE/JNZ Jump if not equal/zero | |||||||||
0 | 0 | 1 | 0 | 0 | 1 | 10-bit signed offset | JEQ/JZ Jump if equal/zero | |||||||||
0 | 0 | 1 | 0 | 1 | 0 | 10-bit signed offset | JNC/JLO Jump if no carry/lower | |||||||||
0 | 0 | 1 | 0 | 1 | 1 | 10-bit signed offset | JC/JHS Jump if carry/higher or same | |||||||||
0 | 0 | 1 | 1 | 0 | 0 | 10-bit signed offset | JN Jump if negative | |||||||||
0 | 0 | 1 | 1 | 0 | 1 | 10-bit signed offset | JGE Jump if greater or equal | |||||||||
0 | 0 | 1 | 1 | 1 | 0 | 10-bit signed offset | JL Jump if less | |||||||||
0 | 0 | 1 | 1 | 1 | 1 | 10-bit signed offset | JMP Jump (unconditionally) | |||||||||
opcode | source | Ad | B/W | As | destination | Two-operand arithmetic | ||||||||||
0 | 1 | 0 | 0 | source | Ad | B/W | As | destination | MOV Move source to destination | |||||||
0 | 1 | 0 | 1 | source | Ad | B/W | As | destination | ADD Add source to destination | |||||||
0 | 1 | 1 | 0 | source | Ad | B/W | As | destination | ADDC Add source and carry to destination | |||||||
0 | 1 | 1 | 1 | source | Ad | B/W | As | destination | SUBC Subtract source from destination (with carry) | |||||||
1 | 0 | 0 | 0 | source | Ad | B/W | As | destination | SUB Subtract source from destination | |||||||
1 | 0 | 0 | 1 | source | Ad | B/W | As | destination | CMP Compare (pretend to subtract) source from destination | |||||||
1 | 0 | 1 | 0 | source | Ad | B/W | As | destination | DADD Decimal add source to destination (with carry) | |||||||
1 | 0 | 1 | 1 | source | Ad | B/W | As | destination | BIT Test bits of source AND destination | |||||||
1 | 1 | 0 | 0 | source | Ad | B/W | As | destination | BIC Bit clear (dest &= ~src) | |||||||
1 | 1 | 0 | 1 | source | Ad | B/W | As | destination | BIS Bit set (logical OR) | |||||||
1 | 1 | 1 | 0 | source | Ad | B/W | As | destination | XOR Exclusive or source with destination | |||||||
1 | 1 | 1 | 1 | source | Ad | B/W | As | destination | AND Logical AND source with destination (dest &= src) |
Instructions are 16 bits, followed by up to two 16-bit extension words. There are four addressing modes, specified by the 2-bit As field. Some special versions can be constructed using R0, and modes other than register direct using R2 (the status register) and R3 (the constant generator) are interpreted specially.
Indexed addressing modes add a 16-bit extension word to the instruction.
As | Register | Syntax | Description |
---|---|---|---|
00 | n | Rn | Register direct. The operand is the contents of Rn. |
01 | n | x(Rn) | Indexed. The operand is in memory at address Rn+x. |
10 | n | @Rn | Register indirect. The operand is in memory at the address held in Rn. |
11 | n | @Rn+ | Indirect autoincrement. As above, then the register is incremented by 1 or 2. |
Addressing modes using R0 (PC) | |||
01 | 0 (PC) | LABEL | Symbolic. x(PC) The operand is in memory at address PC+x. |
11 | 0 (PC) | #x | Immediate. @PC+ The operand is the next word in the instruction stream. |
Addressing modes using R2 (SR) and R3 (CG), special-case decoding | |||
01 | 2 (SR) | &LABEL | Absolute. The operand is in memory at address x. |
10 | 2 (SR) | #4 | Constant. The operand is the constant 4. |
11 | 2 (SR) | #8 | Constant. The operand is the constant 8. |
00 | 3 (CG) | #0 | Constant. The operand is the constant 0. |
01 | 3 (CG) | #1 | Constant. The operand is the constant 1. There is no index word. |
10 | 3 (CG) | #2 | Constant. The operand is the constant 2. |
11 | 3 (CG) | #-1 | Constant. The operand is the constant -1. |
Instructions generally take 1 cycle per word fetched or stored, so instruction times range from 1 cycle for a simple register-register instruction to 6 cycles for an instruction with both source and destination indexed.
Moves to the program counter are allowed and perform jumps. Return from subroutine, for example, is implemented as MOV @SP+,PC. In the two-operand instructions, there is only one Ad bit to specify the destination addressing mode, so only modes 00 (register direct) and 01 (indexed) are allowed. If both source and destination are indexed, the source extension word comes first.
When R0 (PC) or R1 (SP) are used with the autoincrement addressing mode, they are always incremented by two. Other registers (R4 through R15) are incremented by the operand size, either 1 or 2 bytes.
The status register contains 4 arithmetic status bits, a global interrupt enable, and 4 bits that disable various clocks to enter low-power mode. When handling an interrupt, the processor saves the status register on the stack and clears the low-power bits. If the interrupt handler does not modify the saved status register, returning from the interrupt will then resume the original low-power mode.
MSP430 address space
The general layout of the MSP430 address space is:
- 0x0000–0x0007
- Processor special function registers (interrupt control registers)
- 0x0008–0x00FF
- 8-bit peripherals. These must be accessed using 8-bit loads and stores.
- 0x0100–0x01FF
- 16-bit peripherals. These must be accessed using 16-bit loads and stores.
- 0x0200–0x09FF
- Up to 2048 bytes of RAM.
- 0x0C00–0x0FFF
- 1024 bytes of bootstrap loader ROM (flash ROM parts only).
- 0x1000-0x1100
- 256 bytes of data flash ROM (flash ROM parts only).
- 0x1100–0x38FF
- Extended RAM on models with more than 2048 bytes of RAM. (0x1100–0x18FF is a copy of 0x0200–0x09FF)
- 0x1100–0xFFFF
- Up to 60 kilobytes of program ROM. Smaller ROMs start at higher addresses. The last 16 or 32 bytes are interrupt vectors.
A few models include more than 2048 bytes of RAM; in that case RAM begins at 0x1100. The first 2048 bytes (0x1100–0x18FF) is mirrored at 0x0200–0x09FF for compatibility. Also, some recent models bend the 8-bit and 16-bit peripheral rules, allowing 16-bit access to peripherals in the 8-bit peripheral address range.
There is a new extended version of the architecture (called MSP430X) which allows a 20-bit address space. It allows additional program ROM beginning at 0x10000.
Peripherals
The MSP430 peripherals are generally easy to use, with (mostly) consistent addresses between models, and no write-only registers.
General-purpose I/O ports 0-10
As is standard on microcontrollers, most pins connect to a more specialized peripheral, but if that peripheral is not needed, the pin may be used for general-purpose I/O. The pins are divided into 8-bit groups called "ports", each of which is controlled by a number of 8-bit registers.
The MSP430 family defines 11 I/O ports, P0 through P10, although no chip implements more than 10 of them. P0 is only implemented on the '3xx family. P7 through P10 are only implemented on the largest members of the '4xx family.
Each port is controlled by the following registers. Ports which do not implement particular features (such as interrupt on state change) do not implement the corresponding registers.
- PxIN
- Port x input. This is a read-only register, and reflects the current state of the pin.
- PxOUT
- Port x output. The values written to this read/write register are driven out the corresponding pins when they are configured to output.
- PxDIR
- Port x data direction. Bits written as 1 configure the corresponding pin for output. Bits written as 0 configure the pin for input.
- PxSEL
- Port x function select. Bits written as 1 configure the corresponding pin for use by the specialized peripheral. Bits written as 0 configure the pin for general-purpose I/O. Port 0 ('3xx parts only) is not multiplexed with other peripherals and does not have a P0SEL register.
- PxIES
- Port x interrupt edge select (ports 0–2 only). Selects the edge which will cause the PxIFG bit to be set. When the input bit changes from matching the PxIES state to not matching it (i.e. whenever a bit in PxIES XOR PxIN changes from clear to set), the corresponding PxIFG bit is set.
- PxIE
- Port x interrupt enable (ports 0–2 only). When this bit and the corresponding PxIFG bit are both set, an interrupt is generated.
- PxIFG
- Port x interrupt flag (ports 0–2 only). Set whenever the corresponding pin makes the state change requested by PxIES. Can be cleared only by software. (Can also be set by software.)
- PxREN
- Port x resistor enable ('2xx only). Bits set in this register enable weak pull-up or pull-down resistors on the corresponding I/O pins even when they are configured as inputs. The direction of the pull is set by the bit written to the PxOUT register.
Note that some pins have special purposes either as inputs or outputs. (For example, timer pins can be configured as capture inputs or PWM outputs.) In this case, the PxDIR bit controls which of the two functions the pin performs even when the PxSEL bit is set. If there is only one special function, then PxDIR is generally ignored.
The PxIN register is still readable if the PxSEL bit is set, but interrupt generation is disabled. If PxSEL is clear, the special function's input is frozen and disconnected from the external pin. Also, configuring a pin for general-purpose output does not disable interrupt generation.
PxIN | PxOUT | PxDIR | PxSEL | PxIES | PxIE | PxIFG | PxREN | |
---|---|---|---|---|---|---|---|---|
P0 | 0x10 | 0x11 | 0x12 | 0x13 | 0x14 | 0x15 | ||
P1 | 0x20 | 0x21 | 0x22 | 0x23 | 0x24 | 0x25 | 0x26 | 0x27 |
P2 | 0x28 | 0x29 | 0x2a | 0x2b | 0x2c | 0x2d | 0x2e | 0x2f |
P3 | 0x18 | 0x19 | 0x1a | 0x1b | 0x10 | |||
P4 | 0x1c | 0x1d | 0x1e | 0x1f | 0x11 | |||
P5 | 0x30 | 0x31 | 0x32 | 0x33 | 0x12 | |||
P6 | 0x34 | 0x35 | 0x36 | 0x37 | 0x13 | |||
P7 | 0x38 | 0x3a | 0x3c | 0x3e | ||||
P8 | 0x39 | 0x3b | 0x3d | 0x3f | ||||
P9 | 0x08 | 0x0a | 0x0c | 0x0e | ||||
P10 | 0x09 | 0x0b | 0x0d | 0x0f |
Ports P7 and P8 may be accessed using 16-bit loads and stores; when used this way, the combination is known as PA. Similarly, P9 and P10 may be combined into a 16-bit PB.
Intelligent Peripherals
- Analog-to-Digital Converter
The MSP430 line offers two types of Analog-to-Digital Conversion (ADC). 10- and 12-bit Successive Approximation converters, as well as a 16-bit Sigma-Delta converter. Data transfer controllers and a 16 word conversion-and-control buffer allow the MSP430 to convert and store samples without CPU intervention, minimizing power consumption.
- Brown Out Reset
The Brown Out Reset circuitry detects low supply voltages and initiates a POR (Power On Reset) signal to reset the device. The MSP430's BOR circuit uses almost no power and is enabled at all times, including in all low power modes.
- Comparator A, A+
The MSP430's comparator module provides precision slope Analog-to-Digital Conversions. Monitors external analog signals and provides voltage and resistor value measurement. Capable of selectable power modes.
- Digital-to-Analog Converter
The MSP430's Digital-to-Analog Converter module features 8- and 12-bit modes and a programmable settling time for low power optimization. Internal or external reference selection is also possible.
- Direct Memory Access Controller
The MSP430's DMA allows data transfers from one address to another without CPU intervention, across the entire address range. Features up to three independent transfer channels.
- ESP430 (integrated in FE42xx devices)
The ESP430CE module performs metering calculations independent of the CPU. Module has separate SD15, HW multiplier, and embedded processor engine.
- LCD/LCD_A/LCD_B
The LCD/LCD_A controller directly drives LCD displays for up to 196 segments. Supports static, 2-mux, 3-mux, and 4-mux LCDs. LCD_A module ihas integrated charge pump for contrast control. LCD_B enables blinking of individual segments with separate blinking memory.
- Op Amps
Feature single supply, low current operation with rail-to-rail outputs and programmable settling times. Software selectable configuration options: unity gain mode, comparator mode, inverting PGA, non-inverting PGA, differential and instrumentation amplifier.
- Hardware multiplier
Some MSP430 models include a memory-mapped hardware multiplier peripheral which performs various 16×16+32→33-bit multiply-accumulate operations. Unusually for the MSP430, this peripheral does include an implicit 2-bit write-only register, which makes it effectively impossible to context switch.
The 8 registers used are:
Address | Name | Function |
---|---|---|
0x130 | MPY | Operand1 for unsigned multiply |
0x132 | MPYS | Operand1 for signed multiply |
0x134 | MAC | Operand1 for unsigned multiply-accumulate |
0x136 | MACS | Operand1 for signed multiply-accumulate |
0x138 | OP2 | Second operand for multiply operation |
0x13a | ResLo | Low word of multiply result |
0x13c | ResHi | High word of multiply result |
0x13e | SumExt | Carry out of multiply-accumulate |
The first operand is written to one of four 16-bit registers. The address written determines the operation performed. While the value written can be read back from any of the registers, the register number written to cannot be recovered.
If a multiply-accumulate operation is desired, the ResLo
and ResHi
registers must also be initialized.
Then, each time a write is performed to the OP2
register, a multiply is performed and the result stored or added to the result registers. The SumExt
register is a read-only register that contains the carry out of the addition (0 or 1) in case of an unsigned multiply), or the sign extension of the 32-bit sum (0 or -1) in case of a signed multiply. In the case of a signed multiply-accumulate, the SumExt
value must be combined with the most significant bit of the prior SumHi
contents to determine the true carry out result (-1, 0, or +1).
The result is available after three clock cycles of delay, which is the time required to fetch a following instruction and a following index word. Thus, the delay is typically invisible. An explicit delay is only required if using an indirect addressing mode to fetch the result.
Development tools
This article needs additional citations for verification. (February 2007) |
Texas Instruments provides software development tools directly, and in conjunction with partners. One such toolchain is the IAR C/C++ compiler and IDE. A Kickstart edition can be downloaded for free from TI or IAR; it is limited to 8KB of C/C++ code in the compiler and debugger (assembly language programs of any size can be developed and debugged with this free toolchain).
TI also combines a version of its own compiler and tools with its Eclipse-based Code Composer Studio IDE ("CCS"). It sells full-featured versions, and offers a free version for download which has a code size limit of 16KB. CCS supports in-circuit emulators, and includes a simulator and other tools; it can also work with other processors sold by TI.
The open source community produces a freely available software development toolset (MSPGCC) based on old versions the GNU toolset, but there is little effort to update it to current versions. Perhaps in part because of that lack of effort, the object code size and speed are not as optimal as the results from a commercial compiler.[citation needed] There is very early llvm-msp430 project, which may eventually provide better support for MSP430 in LLVM.
Other commercial development toolsets, which include editor, compiler, linker, assembler, debugger and in some cases code wizards, are available. VisSim, a block diagram language for model based development, can generate efficient fixed point C-Code directly from the diagram. By clever use of inline interrupt functions, VisSim generates very efficient control programs that can access I2C, ADC, PWM etc, in a control loop and use less than 1K flash and 128 bytes RAM.
Development platforms
The MSP430 has generated excitement with the availability of inexpensive development platforms. At a cost of $20 USD, TI has packaged a USB stick programmer, the eZ430-F2013, containing an MSP430F2013 on a detachable prototyping board, and CD with development software. This is helpful for schools, hobbyists and garage inventors. It is also welcomed by engineers in large companies prototyping projects with capital budget problems.
One other interesting thing about the MSP430F2013 and its siblings is that it is the only MSP430 part that is available in a dual in-line package (DIP). Other variants in this family are only available in various surface-mount packages. It is clear that TI has gone to some trouble to support the eZ430 development platform by making the raw chips easily prototypable by hobbyists.
Debugging interface
In common with other microcontroller vendors, TI has developed a two-wire debugging interface found on some of their MSP430 parts that can replace the larger JTAG interface. The eZ430 Development Tool contains a full USB-connected Flash Emulation Tool ("FET") for this new two-wire protocol, named "Spy-Bi-Wire" by TI. Spy-Bi-Wire was initially introduced on only the smallest devices in the 'F2xx family with limited number of I/O pins, such as the MSP430F20xx, MSP430F21x2, and MSP430F22x2. The support for Spy-Bi-Wire has been expanded with the introduction of the latest '5xx family, where all devices have support Spy-Bi-Wire interface in addition to JTAG.
The advantage of the Spy-Bi-Wire protocol is that it uses only two communication lines, one of which is the dedicated _RESET line. The JTAG interface on the lower pin count MSP430 parts is multiplexed with general purpose I/O lines. This makes it relatively difficult to debug circuits built around the small, low-I/O-budget chips, since the full 4-pin JTAG hardware will conflict with anything else connected to those I/O lines. This problem is alleviated with the Spy-Bi-Wire-capable chips, which are still compatible with the normal JTAG interface for backwards compatibility with the old development tools.
JTAG debugging and flash programming tools based on OpenOCD and widely used in the ARM community are not available for the MSP430. Programming tools specially designed for the MSP430 are marginally less expensive than JTAG interfaces that use OpenOCD. However, should a project discover midstream that more MIPS, more memory, and more I/O peripherals are needed, those tools will not transfer to a processor from another vendor.
References
- ^ "MSP430 Ultra-Low-Power Microcontroller" (PDF). Texas Instruments. Retrieved 2008-07-09.
External links
Community and information sites
- TI MSP430 Homepage
- TI MSP430 Community forum
- MSP430 Community sponsored by Texas Instruments
- msp430 Yahoo!group
- MSP430.info
- MSP430 English-Japanese forum
Visual programming C code generators
Compilers, assemblers and IDEs
Free Compiler and IDEs
- TI Code Composer Studio IDE, Microcontroller Core Edition (size limited to 16KB)
- IAR Embedded Workbench Kickstart IDE (size limited to 4/8/16KB - depends on device used)
- GCC toolchain for the MSP430 Microcontrollers
Most Popular Unrestricted IDEs and Compilers
- IAR Embedded Workbench for TI MSP430
- TI Code Composer Studio (CCS) Microcontroller or Platinum editions
- Rowley CrossWorks for MSP430
- GCC toolchain for the MSP430 Microcontrollers (Free C-compiler)
Miscellaneous IDEs
- AQ430 Development Tools for MSP430 Microcontrollers
- ImageCraft C Tools
- ForthInc Forth-Compiler
- MPE Forth-Compiler
- HI-TECH C for MSP430 (Dropped MSP430 Support in 2009)