[protocol spec] In the Orchard Action statement, the Merkle path should be from Extract_ℙ(cm^old)
In § 4.18.4 ‘Action Statement (Orchard)’,
Merkle path validity Either $\mathsf{v^{old}} = 0$; or $(\mathsf{path}, \mathsf{pos})$ is a valid Merkle path of depth $\mathsf{MerkleDepth^{Orchard}}$, as defined in § 4.9 ‘Merkle Path Validity’ on p. 47, from $\mathsf{cm^{old}}$ to the anchor $\mathsf{rt^{Orchard}}$.
should be
Merkle path validity Either $\mathsf{v^{old}} = 0$; or $(\mathsf{path}, \mathsf{pos})$ is a valid Merkle path of depth $\mathsf{MerkleDepth^{Orchard}}$, as defined in § 4.9 ‘Merkle Path Validity’ on p. 47, from $\mathsf{Extract}_{\mathbb{P}}(\mathsf{cm^{old}})$ to the anchor $\mathsf{rt^{Orchard}}$.
(i.e. the path is from $\mathsf{cm}_x^{\mathsf{old}}$).
This is a specification-only bug; it is implemented as intended in the orchard crate. There are no security consequences.
This bug was found during a review of the Namada airdrop protocol.