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 load; RV32 Zclsd: compressed load of a 64-bit value into an even/odd register pair.
C.LD (CL format, rd' and rs1' x8-x15, RV64C only) loads 64-bit value from address rs1' + zero-extended offset (×8) into rd'. Expands to ld rd',offset(rs1'). Part of Zclsd (or C extension for RV64C).
C.LD is the 16-bit encoding form for compressed doubleword load; its semantics and encodable register/immediate ranges must be read from the official C extension rules.
Understand this scenario with real code like «c.ld x8, 0(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.