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.
Jump via register; write pc+2 to x1. CR format. rs1!=x0.
C.JALR (CR format) jumps to address in rs1, writes pc+2 to x1(ra). Expands to jalr x1,0(rs1). Valid only when rs1≠x0 (rs1=x0 is C.EBREAK). Link address offset is 2 bytes (vs 4 bytes for 32-bit Jalr).
C.JALR is the 16-bit encoding form for compressed jump and link register; its semantics and encodable register/immediate ranges must be read from the official C extension rules.
Understand this scenario with real code like «c.jalr ra # call *ra, retaddr to ra».
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.