# How can I direct sum matrices into the middle of one another another?

I would like to execute the mathematical operation of the direct sum of matrices in the case where the matrices are not appended one after the other along the diagonal, but instead mixed among one another. This must be generalizable to any permutation of mixing indices along the diagonal.

For example, say we have matrix A, B and C $$A=$$\begin{bmatrix} cos (t) & sin(t) \ -sin(t) & cos(t) \end{bmatrix}$$$$

$$B=$$\begin{bmatrix} 1 & 0 \ 0 & 1 \end{bmatrix}$$$$

$$C=$$\begin{bmatrix} cos (u) & sin(u) \ -sin(u) & cos(u) \end{bmatrix}$$$$

$$A ? B ? C=$$\begin{bmatrix} cos (t) & sin(t) & 0 & 0 & 0 & 0\ -sin(t) & cos(t) & 0 & 0 & 0 & 0\ 0 & 0 & 1 & 0 & 0 & 0\ 0 & 0 & 0 & cos(u) & 0 & sin(u)\ 0 & 0 & 0 & 0 & 1 & 0\ 0 & 0 & 0 & -sin(u) & 0 & cos(u) \end{bmatrix}$$$$

How would this be done in a generalizable way in Mathematica? One could use a permutation matrix, $$P=$$\begin{bmatrix} 1 & 0 & 0 & 0 & 0 & 0\ 0 & 1 & 0 & 0 & 0 & 0\ 0 & 0 & 1 & 0 & 0 & 0\ 0 & 0 & 0 & 0 & 1 & 0\ 0 & 0 & 0 & 1 & 0 & 0\ 0 & 0 & 0 & 0 & 0 & 1 \end{bmatrix}$$$$ where, $$A?B?C=P[A⊕B⊕C]P^T$$, but how could I create such a matrix P in mathematica knowing only what the mapping is? In this case, the index mapping being: (1,2,3,4,5,6)->(1,2,3,5,4,6)