SLAU144K December 2004 – August 2022 MSP430AFE221 , MSP430AFE222 , MSP430AFE223 , MSP430AFE231 , MSP430AFE232 , MSP430AFE233 , MSP430AFE251 , MSP430AFE252 , MSP430AFE253 , MSP430F2001 , MSP430F2002 , MSP430F2003 , MSP430F2011 , MSP430F2012 , MSP430F2013 , MSP430F2101 , MSP430F2111 , MSP430F2112 , MSP430F2121 , MSP430F2122 , MSP430F2131 , MSP430F2132 , MSP430F2132-EP , MSP430F2232 , MSP430F2234 , MSP430F2252 , MSP430F2252-Q1 , MSP430F2254 , MSP430F2272 , MSP430F2272-Q1 , MSP430F2274 , MSP430F2274-EP , MSP430F233 , MSP430F2330 , MSP430F235 , MSP430F2350 , MSP430F2370 , MSP430F2410 , MSP430F2416 , MSP430F2417 , MSP430F2418 , MSP430F2419 , MSP430F247 , MSP430F2471 , MSP430F248 , MSP430F2481 , MSP430F249 , MSP430F2491 , MSP430F2616 , MSP430F2617 , MSP430F2618 , MSP430F2619 , MSP430G2001 , MSP430G2101 , MSP430G2102 , MSP430G2111 , MSP430G2112 , MSP430G2121 , MSP430G2131 , MSP430G2132 , MSP430G2152 , MSP430G2153 , MSP430G2201 , MSP430G2201-Q1 , MSP430G2202 , MSP430G2203 , MSP430G2210 , MSP430G2211 , MSP430G2212 , MSP430G2213 , MSP430G2221 , MSP430G2230 , MSP430G2231 , MSP430G2231-Q1 , MSP430G2232 , MSP430G2233 , MSP430G2252 , MSP430G2253 , MSP430G2302 , MSP430G2303 , MSP430G2312 , MSP430G2313 , MSP430G2332 , MSP430G2333 , MSP430G2352 , MSP430G2353 , MSP430G2402 , MSP430G2403 , MSP430G2412 , MSP430G2413 , MSP430G2432 , MSP430G2433 , MSP430G2444 , MSP430G2452 , MSP430G2453 , MSP430G2513 , MSP430G2533 , MSP430G2544 , MSP430G2553 , MSP430G2744 , MSP430G2755 , MSP430G2855 , MSP430G2955 , MSP430TCH5E
Extended MSP430X Format II instructions are listed in Table 4-14.
Mnemonic | Operands | Operation | Status Bits (1) | ||||
---|---|---|---|---|---|---|---|
n | V | N | Z | C | |||
CALLA | dst | Call indirect to subroutine (20-bit address) | – | – | – | – | |
POPM.A | #n,Rdst | Pop n 20-bit registers from stack | 1 to 16 | – | – | – | – |
POPM.W | #n,Rdst | Pop n 16-bit registers from stack | 1 to 16 | – | – | – | – |
PUSHM.A | #n,Rsrc | Push n 20-bit registers to stack | 1 to 16 | – | – | – | – |
PUSHM.W | #n,Rsrc | Push n 16-bit registers to stack | 1 to 16 | – | – | – | – |
PUSHX(.B,.A) | src | Push 8/16/20-bit source to stack | – | – | – | – | |
RRCM(.A) | #n,Rdst | Rotate right Rdst n bits through carry (16-/20-bit register) | 1 to 4 | 0 | * | * | * |
RRUM(.A) | #n,Rdst | Rotate right Rdst n bits unsigned (16-/20-bit register) | 1 to 4 | 0 | * | * | * |
RRAM(.A) | #n,Rdst | Rotate right Rdst n bits arithmetically (16-/20-bit register) | 1 to 4 | * | * | * | * |
RLAM(.A) | #n,Rdst | Rotate left Rdst n bits arithmetically (16-/20-bit register) | 1 to 4 | * | * | * | * |
RRCX(.B,.A) | dst | Rotate right dst through carry (8-/16-/20-bit data) | 1 | 0 | * | * | * |
RRUX(.B,.A) | Rdst | Rotate right dst unsigned (8-/16-/20-bit) | 1 | 0 | * | * | * |
RRAX(.B,.A) | dst | Rotate right dst arithmetically | 1 | * | * | * | * |
SWPBX(.A) | dst | Exchange low byte with high byte | 1 | – | – | – | – |
SXTX(.A) | Rdst | Bit7 → bit8 ... bit19 | 1 | 0 | * | * | * |
SXTX(.A) | dst | Bit7 → bit8 ... MSB | 1 | 0 | * | * | * |
The three possible addressing mode combinations for Format II instructions are shown in Figure 4-30.