كيف يمكنني كتابة رمز التجميع المضمن التالي في Visual C ++ 6.0؟

StackOverflow https://stackoverflow.com/questions/1163031

سؤال

أنا أكتب تطبيقا في C في دول مجلس التعاون الخليجي (لنظام التشغيل Linux / Ubuntu) يستخدم التجميع المضمن التالي.

float a[4] = { 10, 20, 30, 40 };
float b[4] = { 0.1, 0.1, 0.1, 0.1 };

asm volatile("movups (%0), %%xmm0\n\t"
             "mulps (%1), %%xmm0\n\t"
             "movups %%xmm0, (%1)"
             :: "r" (a), "r" (b));

عذر الأخطاء المطبعية في أعلاه (أنا أكتب من الذاكرة). ما هو التعداد المضمن المكافئ في Visual C ++ 6.0؟ لقد اكتشفت أنني بحاجة إلى ميناء التعليمات البرمجية الخاصة بي.

هل كانت مفيدة؟

المحلول

__declspec(align(16)) float a[4] = { 10, 20, 30, 40 };
__declspec(align(16)) float b[4] = { 0.1f, 0.1f, 0.1f, 0.1f };

__asm {
    movups xmm0, a; // could be movaps if array aligned
    mulps xmm0, b;
    movups b, xmm0; // could be movaps if array aligned
}

لست متأكدا من Visual C ++ 6، ولكن سيعمل في Visual C ++ 2008.

مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top