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.
Restore registers, deallocate frame, and ret
CM.POPRET (Zcmp) pops registers in {reg_list}, adjusts sp, then executes ret (jump to ra). Used for function epilogues returning non-zero values. Reuses c.fsdsp encoding, incompatible with Zcd. sp adjustment and ret must commit atomically. Part of Zcmp, depends on Zca.
CM.POPRET is the 16-bit encoding form for compressed pop and return; its semantics and encodable register/immediate ranges must be read from the official Zc extension rules.
Understand this scenario with real code like «cm.popret {ra, s0-s3}, 32 # pop ra,s0-s3, sp+=32, ret».
Understand this scenario with real code like «cm.popret {ra, s0-s3}, 32 # pop ra,s0-s3, sp+=32, ret».
Understand this scenario with real code like «cm.popret {ra, s0-s3}, 32 # pop ra,s0-s3, sp+=32, ret».
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.