I would be surprised if modern CPUs didn't decode "xor eax, eax" into a set of micro-ops that simply moves from an externally invisible dedicated 0 register. These days the x86 ISA is more of an API contract than an actual representation of what the hardware internals do.
Zero micro ops to be precise, that’s handled entirely at the register rename stage with no data movement.
From TFA: