

# CAO Clock Cycles

Eduard Fekete

Character Count: 7662

Word Count: 1850

December 25, 2025

| Mnemonic     | Operands | Description                                          | Clock Cycles         |
|--------------|----------|------------------------------------------------------|----------------------|
| <b>ADC</b>   | Rd, Rr   | Add with Carry                                       | 1                    |
| <b>ADD</b>   | Rd, Rr   | Add without Carry                                    | 1                    |
| <b>ADIW</b>  | Rd, K    | Add Immediate to Word                                | 2                    |
| <b>AND</b>   | Rd, Rr   | Logical AND                                          | 1                    |
| <b>ANDI</b>  | Rd, K    | Logical AND with Immediate                           | 1                    |
| <b>ASR</b>   | Rd       | Arithmetic Shift Right                               | 1                    |
| <b>BCLR</b>  | s        | Bit Clear in SREG                                    | 1                    |
| <b>BLD</b>   | Rd, b    | Bit Load from the T Bit in SREG to a Bit in Register | 1                    |
| <b>BRBC</b>  | s, k     | Branch if Bit in SREG is Cleared                     | 1 (false) / 2 (true) |
| <b>BRBS</b>  | s, k     | Branch if Bit in SREG is Set                         | 1 (false) / 2 (true) |
| <b>BRCC</b>  | k        | Branch if Carry Cleared                              | 1 (false) / 2 (true) |
| <b>BRCS</b>  | k        | Branch if Carry Set                                  | 1 (false) / 2 (true) |
| <b>BREAK</b> | None     | Break                                                | 1                    |
| <b>BREQ</b>  | k        | Branch if Equal                                      | 1 (false) / 2 (true) |
| <b>BRGE</b>  | k        | Branch if Greater or Equal (Signed)                  | 1 (false) / 2 (true) |
| <b>BRHC</b>  | k        | Branch if Half Carry Flag is Cleared                 | 1 (false) / 2 (true) |
| <b>BRHS</b>  | k        | Branch if Half Carry Flag is Set                     | 1 (false) / 2 (true) |
| <b>BRID</b>  | k        | Branch if Global Interrupt is Disabled               | 1 (false) / 2 (true) |
| <b>BRIE</b>  | k        | Branch if Global Interrupt is Enabled                | 1 (false) / 2 (true) |
| <b>BRLO</b>  | k        | Branch if Lower (Unsigned)                           | 1 (false) / 2 (true) |
| <b>BRLT</b>  | k        | Branch if Less Than (Signed)                         | 1 (false) / 2 (true) |
| <b>BRMI</b>  | k        | Branch if Minus                                      | 1 (false) / 2 (true) |
| <b>BRNE</b>  | k        | Branch if Not Equal                                  | 1 (false) / 2 (true) |
| <b>BRPL</b>  | k        | Branch if Plus                                       | 1 (false) / 2 (true) |
| <b>BRSH</b>  | k        | Branch if Same or Higher (Unsigned)                  | 1 (false) / 2 (true) |
| <b>BRTC</b>  | k        | Branch if the T Bit is Cleared                       | 1 (false) / 2 (true) |
| <b>BRTS</b>  | k        | Branch if the T Bit is Set                           | 1 (false) / 2 (true) |
| <b>BRVC</b>  | k        | Branch if Overflow Cleared                           | 1 (false) / 2 (true) |
| <b>BRVS</b>  | k        | Branch if Overflow Set                               | 1 (false) / 2 (true) |
| <b>BSET</b>  | s        | Bit Set in SREG                                      | 1                    |
| <b>BST</b>   | Rd, b    | Bit Store from Bit in Register to T Bit in SREG      | 1                    |
| <b>CALL</b>  | k        | Long Call to a Subroutine                            | 4                    |
| <b>CBI</b>   | A, b     | Clear Bit in I/O Register                            | 2                    |
| <b>CBR</b>   | Rd, K    | Clear Bits in Register                               | 1                    |
| <b>CLC</b>   | None     | Clear Carry Flag                                     | 1                    |
| <b>CLH</b>   | None     | Clear Half Carry Flag                                | 1                    |

| Mnemonic      | Operands     | Description                                       | Clock Cycles                                     |
|---------------|--------------|---------------------------------------------------|--------------------------------------------------|
| <b>CLI</b>    | None         | Clear Global Interrupt Enable Bit                 | 1                                                |
| <b>CLN</b>    | None         | Clear Negative Flag                               | 1                                                |
| <b>CLR</b>    | Rd           | Clear Register                                    | 1                                                |
| <b>CLS</b>    | None         | Clear Sign Flag                                   | 1                                                |
| <b>CLT</b>    | None         | Clear T Bit                                       | 1                                                |
| <b>CLV</b>    | None         | Clear Overflow Flag                               | 1                                                |
| <b>CLZ</b>    | None         | Clear Zero Flag                                   | 1                                                |
| <b>COM</b>    | Rd           | One's Complement                                  | 1                                                |
| <b>CP</b>     | Rd, Rr       | Compare                                           | 1                                                |
| <b>CPC</b>    | Rd, Rr       | Compare with Carry                                | 1                                                |
| <b>CPI</b>    | Rd, K        | Compare with Immediate                            | 1                                                |
| <b>CPSE</b>   | Rd, Rr       | Compare Skip if Equal                             | 1 (false) / 2 (true, 1 word) / 3 (true, 2 words) |
| <b>DEC</b>    | Rd           | Decrement                                         | 1                                                |
| <b>EICALL</b> | None         | Extended Indirect Call to Subroutine              | 4                                                |
| <b>EIJMP</b>  | None         | Extended Indirect Jump                            | 2                                                |
| <b>ELPM</b>   | None, Rd, Z+ | Extended Load Program Memory                      | 3                                                |
| <b>EOR</b>    | Rd, Rr       | Exclusive OR                                      | 1                                                |
| <b>FMUL</b>   | Rd, Rr       | Fractional Multiply Unsigned                      | 2                                                |
| <b>FMULS</b>  | Rd, Rr       | Fractional Multiply Signed                        | 2                                                |
| <b>FMULSU</b> | Rd, Rr       | Fractional Multiply Signed with Unsigned          | 2                                                |
| <b>ICALL</b>  | None         | Indirect Call to Subroutine                       | 3                                                |
| <b>IJMP</b>   | None         | Indirect Jump                                     | 2                                                |
| <b>IN</b>     | Rd, A        | Load an I/O Location to Register                  | 1                                                |
| <b>INC</b>    | Rd           | Increment                                         | 1                                                |
| <b>JMP</b>    | k            | Jump                                              | 3                                                |
| <b>LD</b>     | Rd, X        | Load Indirect from Data Space to Register using X | 2                                                |
| <b>LD</b>     | Rd, X+       | Load Indirect using X (Post-increment)            | 2                                                |
| <b>LD</b>     | Rd, -X       | Load Indirect using X (Pre-decrement)             | 2                                                |
| <b>LD</b>     | Rd, Y        | Load Indirect from Data Space to Register using Y | 2                                                |
| <b>LD</b>     | Rd, Y+       | Load Indirect using Y (Post-increment)            | 2                                                |
| <b>LD</b>     | Rd, -Y       | Load Indirect using Y (Pre-decrement)             | 2                                                |
| <b>LDD</b>    | Rd, Y+q      | Load Indirect using Y with Displacement           | 2                                                |
| <b>LD</b>     | Rd, Z        | Load Indirect from Data Space to Register using Z | 2                                                |
| <b>LD</b>     | Rd, Z+       | Load Indirect using Z (Post-increment)            | 2                                                |
| <b>LD</b>     | Rd, -Z       | Load Indirect using Z (Pre-decrement)             | 2                                                |

| Mnemonic     | Operands     | Description                             | Clock Cycles                                     |
|--------------|--------------|-----------------------------------------|--------------------------------------------------|
| <b>LDD</b>   | Rd, Z+q      | Load Indirect using Z with Displacement | 2                                                |
| <b>LDI</b>   | Rd, K        | Load Immediate                          | 1                                                |
| <b>LDS</b>   | Rd, k        | Load Direct from Data Space             | 2                                                |
| <b>LPM</b>   | None, Rd, Z+ | Load Program Memory                     | 3                                                |
| <b>LSL</b>   | Rd           | Logical Shift Left                      | 1                                                |
| <b>LSR</b>   | Rd           | Logical Shift Right                     | 1                                                |
| <b>MOV</b>   | Rd, Rr       | Copy Register                           | 1                                                |
| <b>MOVW</b>  | Rd, Rr       | Copy Register Word                      | 1                                                |
| <b>MUL</b>   | Rd, Rr       | Multiply Unsigned                       | 2                                                |
| <b>MULS</b>  | Rd, Rr       | Multiply Signed                         | 2                                                |
| <b>MULSU</b> | Rd, Rr       | Multiply Signed with Unsigned           | 2                                                |
| <b>NEG</b>   | Rd           | Two's Complement                        | 1                                                |
| <b>NOP</b>   | None         | No Operation                            | 1                                                |
| <b>OR</b>    | Rd, Rr       | Logical OR                              | 1                                                |
| <b>ORI</b>   | Rd, K        | Logical OR with Immediate               | 1                                                |
| <b>OUT</b>   | A, Rr        | Store Register to I/O Location          | 1                                                |
| <b>POP</b>   | Rd           | Pop Register from Stack                 | 2                                                |
| <b>PUSH</b>  | Rr           | Push Register on Stack                  | 2                                                |
| <b>RCALL</b> | k            | Relative Call to Subroutine             | 3                                                |
| <b>RET</b>   | None         | Return from Subroutine                  | 4                                                |
| <b>RETI</b>  | None         | Return from Interrupt                   | 4                                                |
| <b>RJMP</b>  | k            | Relative Jump                           | 2                                                |
| <b>ROL</b>   | Rd           | Rotate Left through Carry               | 1                                                |
| <b>ROR</b>   | Rd           | Rotate Right through Carry              | 1                                                |
| <b>SBC</b>   | Rd, Rr       | Subtract with Carry                     | 1                                                |
| <b>SBCI</b>  | Rd, K        | Subtract Immediate with Carry           | 1                                                |
| <b>SBI</b>   | A, b         | Set Bit in I/O Register                 | 2                                                |
| <b>SBIC</b>  | A, b         | Skip if Bit in I/O Register is Cleared  | 1 (false) / 2 (true, 1 word) / 3 (true, 2 words) |
| <b>SBIS</b>  | A, b         | Skip if Bit in I/O Register is Set      | 1 (false) / 2 (true, 1 word) / 3 (true, 2 words) |
| <b>SBIW</b>  | Rd, K        | Subtract Immediate from Word            | 2                                                |
| <b>SBR</b>   | Rd, K        | Set Bits in Register                    | 1                                                |
| <b>SBRC</b>  | Rr, b        | Skip if Bit in Register is Cleared      | 1 (false) / 2 (true, 1 word) / 3 (true, 2 words) |
| <b>SBRS</b>  | Rr, b        | Skip if Bit in Register is Set          | 1 (false) / 2 (true, 1 word) / 3 (true, 2 words) |
| <b>SEC</b>   | None         | Set Carry Flag                          | 1                                                |
| <b>SEH</b>   | None         | Set Half Carry Flag                     | 1                                                |
| <b>SEI</b>   | None         | Set Global Interrupt Enable Bit         | 1                                                |
| <b>SEN</b>   | None         | Set Negative Flag                       | 1                                                |
| <b>SER</b>   | Rd           | Set all Bits in Register                | 1                                                |

| Mnemonic     | Operands | Description                                        | Clock Cycles             |
|--------------|----------|----------------------------------------------------|--------------------------|
| <b>SES</b>   | None     | Set Sign Flag                                      | 1                        |
| <b>SET</b>   | None     | Set T Bit                                          | 1                        |
| <b>SEV</b>   | None     | Set Overflow Flag                                  | 1                        |
| <b>SEZ</b>   | None     | Set Zero Flag                                      | 1                        |
| <b>SLEEP</b> | None     | Enter Sleep Mode                                   | 1                        |
| <b>SPM</b>   | None     | Store Program Memory                               | - (Depends on operation) |
| <b>ST</b>    | X, Rr    | Store Indirect from Register to Data Space using X | 2                        |
| <b>ST</b>    | X+, Rr   | Store Indirect using X (Post-increment)            | 2                        |
| <b>ST</b>    | -X, Rr   | Store Indirect using X (Pre-decrement)             | 2                        |
| <b>ST</b>    | Y, Rr    | Store Indirect from Register to Data Space using Y | 2                        |
| <b>ST</b>    | Y+, Rr   | Store Indirect using Y (Post-increment)            | 2                        |
| <b>ST</b>    | -Y, Rr   | Store Indirect using Y (Pre-decrement)             | 2                        |
| <b>STD</b>   | Y+q, Rr  | Store Indirect using Y with Displacement           | 2                        |
| <b>ST</b>    | Z, Rr    | Store Indirect from Register to Data Space using Z | 2                        |
| <b>ST</b>    | Z+, Rr   | Store Indirect using Z (Post-increment)            | 2                        |
| <b>ST</b>    | -Z, Rr   | Store Indirect using Z (Pre-decrement)             | 2                        |
| <b>STD</b>   | Z+q, Rr  | Store Indirect using Z with Displacement           | 2                        |
| <b>STS</b>   | k, Rr    | Store Direct to Data Space                         | 2                        |
| <b>SUB</b>   | Rd, Rr   | Subtract Without Carry                             | 1                        |
| <b>SUBI</b>  | Rd, K    | Subtract Immediate                                 | 1                        |
| <b>SWAP</b>  | Rd       | Swap Nibbles                                       | 1                        |
| <b>TST</b>   | Rd       | Test for Zero or Minus                             | 1                        |
| <b>WDR</b>   | None     | Watchdog Reset                                     | 1                        |