Lines 643-668
Link Here
|
643 |
"punpcklwd %%mm0, %%mm1 \n\t" |
643 |
"punpcklwd %%mm0, %%mm1 \n\t" |
644 |
"punpckhwd %%mm4, %%mm3 \n\t" |
644 |
"punpckhwd %%mm4, %%mm3 \n\t" |
645 |
"punpckhwd %%mm0, %%mm6 \n\t" |
645 |
"punpckhwd %%mm0, %%mm6 \n\t" |
646 |
"movd %%mm5, %0 \n\t" |
646 |
"movd %%mm5, (%0) \n\t" |
647 |
"punpckhdq %%mm5, %%mm5 \n\t" |
647 |
"punpckhdq %%mm5, %%mm5 \n\t" |
648 |
"movd %%mm5, %1 \n\t" |
648 |
"movd %%mm5, (%0,%2) \n\t" |
649 |
"movd %%mm3, %2 \n\t" |
649 |
"movd %%mm3, (%0,%2,2) \n\t" |
650 |
"punpckhdq %%mm3, %%mm3 \n\t" |
650 |
"punpckhdq %%mm3, %%mm3 \n\t" |
651 |
"movd %%mm3, %3 \n\t" |
651 |
"movd %%mm3, (%0,%3) \n\t" |
652 |
"movd %%mm1, %4 \n\t" |
652 |
"movd %%mm1, (%1) \n\t" |
653 |
"punpckhdq %%mm1, %%mm1 \n\t" |
653 |
"punpckhdq %%mm1, %%mm1 \n\t" |
654 |
"movd %%mm1, %5 \n\t" |
654 |
"movd %%mm1, (%1,%2) \n\t" |
655 |
"movd %%mm6, %6 \n\t" |
655 |
"movd %%mm6, (%1,%2,2) \n\t" |
656 |
"punpckhdq %%mm6, %%mm6 \n\t" |
656 |
"punpckhdq %%mm6, %%mm6 \n\t" |
657 |
"movd %%mm6, %7 \n\t" |
657 |
"movd %%mm6, (%1,%3) \n\t" |
658 |
: "=m" (*(uint32_t*)(src + 0*stride)), |
658 |
:: "r" (src), |
659 |
"=m" (*(uint32_t*)(src + 1*stride)), |
659 |
"r" (src + 4*stride), |
660 |
"=m" (*(uint32_t*)(src + 2*stride)), |
660 |
"r" ((long) stride ), |
661 |
"=m" (*(uint32_t*)(src + 3*stride)), |
661 |
"r" ((long)(3*stride)) |
662 |
"=m" (*(uint32_t*)(src + 4*stride)), |
|
|
663 |
"=m" (*(uint32_t*)(src + 5*stride)), |
664 |
"=m" (*(uint32_t*)(src + 6*stride)), |
665 |
"=m" (*(uint32_t*)(src + 7*stride)) |
666 |
); |
662 |
); |
667 |
} |
663 |
} |
668 |
|
664 |
|