Is it always equivalent to a same-named 32-bit instruction?
Not always. Some C/Zc instructions compress common 32-bit operations, while others have dedicated stack-frame or table-jump semantics.
Save ra and s0-s11 to stack and adjust sp
CM.PUSH (Zcmp) pushes registers in {reg_list} (ra and up to 12 s-registers) to stack and decrements sp by stack_adj. stack_adj = stack_adj_base + spimm×16. Reuses c.fsdsp encoding, incompatible with Zcd. Stores may execute multiple times (fault recovery); sp adjustment commits atomically. Part of Zcmp, depends on Zca.
CM.PUSH is the 16-bit encoding form for compressed push multiple registers; its semantics and encodable register/immediate ranges must be read from the official Zc extension rules.
Understand this scenario with real code like «cm.push {ra, s0-s5}, -64 # save ra,s0-s5, sp-=64».
Understand this scenario with real code like «cm.push {ra, s0-s5}, -64 # save ra,s0-s5, sp-=64».
Not always. Some C/Zc instructions compress common 32-bit operations, while others have dedicated stack-frame or table-jump semantics.
Many 16-bit encodings can represent only a compressed register subset or fixed registers such as sp, ra, a0/a1.