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.
16-bit encoding of mul, low XLEN bits of product
C.MUL (Zcb, CA format) multiplies rsd' and rs2', writes low XLEN bits to rsd'. rd' and rs2' limited to x8-x15. Requires M or Zmmul. Expands to mul rsd',rsd',rs2'. Part of Zcb, depends on Zca and M/Zmmul.
C.MUL is the 16-bit encoding form for compressed multiply; its semantics and encodable register/immediate ranges must be read from the official C extension rules.
Understand this scenario with real code like «c.mul x10, x11 # x10 = (x10 * x11)[XLEN-1:0]».
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.