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.
RV64C: compressed 64-bit doubleword store; RV32 Zclsd: compressed store of a 64-bit value from an even/odd register pair.
C.SDSP (CSS format, rs2 any of 32, RV64C only) stores 64-bit value of rs2 to address sp(x2) + zero-extended offset (×8). Expands to sd rs2,offset(x2).
C.SDSP is the 16-bit encoding form for compressed stack doubleword store; its semantics and encodable register/immediate ranges must be read from the official C extension rules.
Understand this scenario with real code like «c.sdsp x10, 16(sp) # *(sp+16) = x10».
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.