With an implicit forall, the code does type check.

So to recap. Explicit/implicit forall doesn't seem to matter here (both compile, both work):

>    pattern Justy ::  a -> Maybe a
>    pattern Justy x = Just x
>
>    pattern Justy2 :: forall a. a -> Maybe a
>    pattern Justy2 x = Just x

(The docos for Pattern Synonyms don't give any examples with explicit `forall`; neither do they discuss whether it makes a difference. I'm inclined to say don't bother with outermost `forall`.)

But it does matter here:

>    data Some where
>      Some :: a -> Some
>
>    pattern Any :: a -> Some
>    pattern Any x = Some x
>
>    pattern Any2 :: forall a. a -> Some
>    pattern Any2 x = Some x
>
>    pattern Any3 :: (forall a. a) -> Some
>    pattern Any3 x = Some x


`Any` is accepted; `Any2` and `Any3` are rejected with a type mismatch/rigid tyvar message per your o.p. (I'm not surprised `Any3` is rejected.) The message complains about the binding line, not the signature. If you don't give a signature for `Any`, we get (with `-fprint-explicit-foralls`) `Any :: forall {a}. a -> Some`, which is the same as for `Justy, Justy2 :: forall {a}. a -> Maybe a` mutatis mutandis.

As to 'working', I presume your actual code doesn't merely have an existential for `Some`(?) but rather a constraint. Otherwise pattern-matching with `(Any x)` or with `(Some x)` you can't do anything with the `x` on RHS.

Your o.p. asked

Is there a way around it, or is this a missing feature?

What feature would you like that you think is "missing"? Do you think a pattern's explicit `forall` for an existential data constructor should do something different vs for a regular datatype?

This could just be a stray loose end that nobody anticipated with Pattern Synonyms.