开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 116|回复: 1
收起左侧

[技术专题] 使用ASMX86MMDA/SSE优化和缓存控制将YY2转换为RGB的单一方法

[复制链接]
结帖率:87% (79/91)
发表于 昨天 09:29 | 显示全部楼层 |阅读模式   江苏省徐州市
[C++] 纯文本查看 复制代码
void BlitYUY2(void* source, void* dest, int larg, int haut, int pitch)
{
        //         _int64 R1B0 = 0x0198010002140100;
        //        _int64 G1G0 = 0x006400D0006400D0;
        _int64 R1B0 = 0x00CC0095010A0095;
        //        _int64 G1G0 = 0xFF980032FF980032;
        //        _int64 Y1Y0 = 0x0000010000000100;
        //        _int64 Y1Y0 = 0x0000009500000095;
        _int64 YU = 0xFFCE0095FFCE0095;
        _int64 GV0 = 0x0000FF980000FF98;
        _int64 GAND = 0x0000FF000000FF00;
        //         _int64 RBAND = 0x00FF00FF00FF00FF;
        _int64 S128 = 0x0080001000800010;
        _asm
        {
                push        ebx
                push        ecx
                push        edx
                push        esi
                push        edi

                mov                esi, source; pointe sur source
                mov     edi, dest
                mov     edx, pitch
                sub     edx, larg; modulo
                pxor        mm7, mm7
                shl     edx, 2; en octet
                mov     ebx, haut
                bcl :
                mov     ecx, larg
                        shr     ecx, 4
                        bcl1 :
                        prefetchnta[esi + 32]
                        movq                mm0, [esi]; V0, Y1, U0, Y0
                        movq                mm4, mm0
                        punpcklbw        mm0, mm7; passe en 16bit

                        punpckhbw        mm4, mm7
                        psubsw                mm0, S128
                        psubsw                mm4, S128

                        pshufw                mm1, mm0, 064h; U0, Y1, U0, Y0
                        pshufw                mm5, mm4, 064h
                        pshufw                mm2, mm0, 0C6h; V0, Y0, U0, Y1

                        pmaddwd                mm0, R1B0; R1, B0
                        pshufw                mm3, mm2, 0FFh; V0, V0, V0, V0
                        pmaddwd                mm1, YU; 0, Y1 + U0, 0, Y0 + U0

                        pmaddwd                mm5, YU; 0, Y1 + U0, 0, Y0 + U0
                        pshufw                mm6, mm4, 0C6h; V0, Y0, U0, Y1
                        pmaddwd                mm4, R1B0; R1, B0

                        psrad                mm0, 7
                        pmaddwd                mm3, GV0
                        paddd                mm1, mm3; G1, G0

                        pshufw                mm3, mm6, 0FFh; V0, V0, V0, V0
                        pmaddwd                mm2, R1B0; R0, B1
                        psrad                mm4, 7

                        psrad                mm2, 7
                        psrad                mm1, 7
                        pmaddwd                mm3, GV0

                        pmaddwd                mm6, R1B0; R0, B1
                        packuswb        mm1, mm1
                        paddd                mm5, mm3; G1, G0

                        packuswb        mm0, mm2; R0, B1, R1, B0
                        psrad                mm6, 7
                        psrad                mm5, 7

                        punpcklbw        mm1, mm1
                        pshufw                mm0, mm0, 06Ch; R1, B1, R0, B0
                        packuswb        mm5, mm5

                        pand                mm1, GAND
                        add                        esi, 8
                        packuswb        mm4, mm6; R0, B1, R1, B0

                        por                        mm0, mm1
                        punpcklbw        mm5, mm5
                        pshufw                mm4, mm4, 06Ch; R1, B1, R0, B0

                        movntq[edi], mm0
                        pand                mm5, GAND
                        por                        mm4, mm5

                        movntq[edi + 8], mm4
                        add         edi, 16
                        ; --------------------------------------------------------------------------------------
                        movq                mm0, [esi]; V0, Y1, U0, Y0
                        movq                mm4, mm0
                        punpcklbw        mm0, mm7; passe en 16bit

                        punpckhbw        mm4, mm7
                        psubsw                mm0, S128
                        psubsw                mm4, S128

                        pshufw                mm1, mm0, 064h; U0, Y1, U0, Y0
                        pshufw                mm5, mm4, 064h
                        pshufw                mm2, mm0, 0C6h; V0, Y0, U0, Y1

                        pmaddwd                mm0, R1B0; R1, B0
                        pshufw                mm3, mm2, 0FFh; V0, V0, V0, V0
                        pmaddwd                mm1, YU; 0, Y1 + U0, 0, Y0 + U0

                        pmaddwd                mm5, YU; 0, Y1 + U0, 0, Y0 + U0
                        pshufw                mm6, mm4, 0C6h; V0, Y0, U0, Y1
                        pmaddwd                mm4, R1B0; R1, B0

                        psrad                mm0, 7
                        pmaddwd                mm3, GV0
                        paddd                mm1, mm3; G1, G0

                        pshufw                mm3, mm6, 0FFh; V0, V0, V0, V0
                        pmaddwd                mm2, R1B0; R0, B1
                        psrad                mm4, 7

                        psrad                mm2, 7
                        psrad                mm1, 7
                        pmaddwd                mm3, GV0

                        pmaddwd                mm6, R1B0; R0, B1
                        packuswb        mm1, mm1
                        paddd                mm5, mm3; G1, G0

                        packuswb        mm0, mm2; R0, B1, R1, B0
                        psrad                mm6, 7
                        psrad                mm5, 7

                        punpcklbw        mm1, mm1
                        pshufw                mm0, mm0, 06Ch; R1, B1, R0, B0
                        packuswb        mm5, mm5

                        pand                mm1, GAND
                        add                        esi, 8
                        packuswb        mm4, mm6; R0, B1, R1, B0

                        por                        mm0, mm1
                        punpcklbw        mm5, mm5
                        pshufw                mm4, mm4, 06Ch; R1, B1, R0, B0

                        movntq[edi], mm0
                        pand                mm5, GAND
                        por                        mm4, mm5

                        movntq[edi + 8], mm4
                        add         edi, 16

                        ; --------------------------------------------------------------------------------------
                        movq                mm0, [esi]; V0, Y1, U0, Y0
                        movq                mm4, mm0
                        punpcklbw        mm0, mm7; passe en 16bit

                        punpckhbw        mm4, mm7
                        psubsw                mm0, S128
                        psubsw                mm4, S128

                        pshufw                mm1, mm0, 064h; U0, Y1, U0, Y0
                        pshufw                mm5, mm4, 064h
                        pshufw                mm2, mm0, 0C6h; V0, Y0, U0, Y1

                        pmaddwd                mm0, R1B0; R1, B0
                        pshufw                mm3, mm2, 0FFh; V0, V0, V0, V0
                        pmaddwd                mm1, YU; 0, Y1 + U0, 0, Y0 + U0

                        pmaddwd                mm5, YU; 0, Y1 + U0, 0, Y0 + U0
                        pshufw                mm6, mm4, 0C6h; V0, Y0, U0, Y1
                        pmaddwd                mm4, R1B0; R1, B0

                        psrad                mm0, 7
                        pmaddwd                mm3, GV0
                        paddd                mm1, mm3; G1, G0

                        pshufw                mm3, mm6, 0FFh; V0, V0, V0, V0
                        pmaddwd                mm2, R1B0; R0, B1
                        psrad                mm4, 7

                        psrad                mm2, 7
                        psrad                mm1, 7
                        pmaddwd                mm3, GV0

                        pmaddwd                mm6, R1B0; R0, B1
                        packuswb        mm1, mm1
                        paddd                mm5, mm3; G1, G0

                        packuswb        mm0, mm2; R0, B1, R1, B0
                        psrad                mm6, 7
                        psrad                mm5, 7

                        punpcklbw        mm1, mm1
                        pshufw                mm0, mm0, 06Ch; R1, B1, R0, B0
                        packuswb        mm5, mm5

                        pand                mm1, GAND
                        add                        esi, 8
                        packuswb        mm4, mm6; R0, B1, R1, B0

                        por                        mm0, mm1
                        punpcklbw        mm5, mm5
                        pshufw                mm4, mm4, 06Ch; R1, B1, R0, B0

                        movntq[edi], mm0
                        pand                mm5, GAND
                        por                        mm4, mm5

                        movntq[edi + 8], mm4
                        add         edi, 16
                        ; --------------------------------------------------------------------------------------
                        movq                mm0, [esi]; V0, Y1, U0, Y0
                        movq                mm4, mm0
                        punpcklbw        mm0, mm7; passe en 16bit

                        punpckhbw        mm4, mm7
                        psubsw                mm0, S128
                        psubsw                mm4, S128

                        pshufw                mm1, mm0, 064h; U0, Y1, U0, Y0
                        pshufw                mm5, mm4, 064h
                        pshufw                mm2, mm0, 0C6h; V0, Y0, U0, Y1

                        pmaddwd                mm0, R1B0; R1, B0
                        pshufw                mm3, mm2, 0FFh; V0, V0, V0, V0
                        pmaddwd                mm1, YU; 0, Y1 + U0, 0, Y0 + U0

                        pmaddwd                mm5, YU; 0, Y1 + U0, 0, Y0 + U0
                        pshufw                mm6, mm4, 0C6h; V0, Y0, U0, Y1
                        pmaddwd                mm4, R1B0; R1, B0

                        psrad                mm0, 7
                        pmaddwd                mm3, GV0
                        paddd                mm1, mm3; G1, G0

                        pshufw                mm3, mm6, 0FFh; V0, V0, V0, V0
                        pmaddwd                mm2, R1B0; R0, B1
                        psrad                mm4, 7

                        psrad                mm2, 7
                        psrad                mm1, 7
                        pmaddwd                mm3, GV0

                        pmaddwd                mm6, R1B0; R0, B1
                        packuswb        mm1, mm1
                        paddd                mm5, mm3; G1, G0

                        packuswb        mm0, mm2; R0, B1, R1, B0
                        psrad                mm6, 7
                        psrad                mm5, 7

                        punpcklbw        mm1, mm1
                        pshufw                mm0, mm0, 06Ch; R1, B1, R0, B0
                        packuswb        mm5, mm5

                        pand                mm1, GAND
                        add                        esi, 8
                        packuswb        mm4, mm6; R0, B1, R1, B0

                        por                        mm0, mm1
                        punpcklbw        mm5, mm5
                        pshufw                mm4, mm4, 06Ch; R1, B1, R0, B0

                        movntq[edi], mm0
                        pand                mm5, GAND
                        por                        mm4, mm5

                        movntq[edi + 8], mm4
                        add         edi, 16


                        dec                ecx
                        jne     bcl1
                        add     edi, edx
                        dec     ebx
                        jne     bcl

                        emms
                        pop                edi
                        pop                esi
                        pop                edx
                        pop                ecx
                        pop                ebx
        }
        return;
}


结帖率:0% (0/1)

签到天数: 3 天

发表于 昨天 14:55 | 显示全部楼层   山西省大同市
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表