ÎÊÌâÃèÊö
FJCVTZS ÊǸ¡¶¯µÄ"-point Javascript ת»»ÎªÓзûºÅ¶¨µã£¬ÏòÁãÉáÈë".Arm v8.3-A оƬ¼°¸ü¸ß°æ±¾Ö§³ÖËü.ÕâºÜÆæ¹Ö£¬ÒòΪÄú²»Ï£Íû¿´µ½ JavaScript Èç´Ë½Ó½üÂã»ú.
FJCVTZS is "Floating-point Javascript Convert to Signed fixed-point, rounding toward Zero". It is supported in Arm v8.3-A chips and later. Which is odd, because you don't expect to see JavaScript so close to the bare metal.
ÎÒ¿ÉÒÔÕÒµ½¸ÃÖ¸Áî×÷ÓõĽâÊÍ£¬µ«ÕÒ²»µ½Ëü´æÔÚµÄÔÒò.Õâ¸öÏß³Ì˵Ëü×÷Ϊµ¥¸öÖ¸Áî´æÔÚÊÇÒòΪ JS ȱÉÙÕûÊýÀàÐÍÒâζ×ÅijЩÓÃÀý¾³£ÒòΪûÓкõÄËã·¨ÔÒò¶øÐèÒª´Ë²Ù×÷.".ÕâËƺõÊǺÏÀíµÄ£¬µ«ÎÒÏëÒª¸üÏêϸµÄÁ˽â.
I can find explanations of what the instruction does, but not why it exists. This thread says "it exists as a single instruction is because JS's lack of an integer type means certain use cases need this operation obscenely often for no good algorithmic reason.". That's plausible but I would like a more detailed understanding.
ÍƼö´ð°¸
ÊÇÒòΪJS¶ÔÊý×ÖʹÓÃÁËË«¾«¶È£¬µ«ÊÇÈç¹ûÄãÏëÓÃλ½øÐÐÔËË㣬ÈÎÎñ¾ÍºÜ²»¼òµ¥ÁË£¬ËùÒÔÓÐÒ»¸ö¾ßÌåµÄÖ¸ÁîÀ´×ª»»JSdouble into integer ʹÊÂÇé±äµÃ¸üÈÝÒ×.
It is because JS uses double precision for the numbers, but if you want to perform operations with bits, the task is nontrivial, so a specific instruction to convert JS double into integer makes the thing easier.
Õâ¸ö ARM Á´½Ó½âÊ͵úܺÃ:https://community.arm.com/processors/b/blog/posts/armv8-a-architecture-2016-additions
This ARM link explains it very well: https://community.arm.com/processors/b/blog/posts/armv8-a-architecture-2016-additions
ΪÁ˲¹³ä¸ü¶à¹ØÓÚfuzµÄ×¢ÊÍÐÅÏ¢£¬FCVTZS
ºÍFJCVTZS
µÄÇø±ð(¶¼Êǽ«¸¡µãÊýת»»Îªint)ÊÇÔÚÒç³öµÄÇé¿öÏ£¬FJCVTZS
Öµ½«ÊÇ 0x80000000 ¶ø²»ÊÇÒç³ö.´ËÍ⣬FJCVTZS
¿ÉÒÔÉú³ÉÒì³£ÒÔָʾת»»µÄ·½Ê½(¼´²»¾«È·).
In order to add more information regarding fuz's comment, the differences between FCVTZS
and FJCVTZS
(both of them convert floating point to int) are that in case of overflow, FJCVTZS
value will be 0x80000000 instead of overflowing. Furthermore, FJCVTZS
can generate an exception in order to indicate how the conversion was (i.e. inexact).
FJCVTZS
: http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0801g/hko1477562192868.html
FCVTZS
: http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0802a/FCVTZS_float_int.html
Õâƪ¹ØÓÚΪʲô ARM оƬµÄÖ¸ÁîÃû³ÆÖдøÓÐ Javascript(FJCVTZS)?µÄÎÄÕ¾ͽéÉܵ½ÕâÁË£¬Ï£ÍûÎÒÃÇÍƼöµÄ´ð°¸¶Ô´ó¼ÒÓÐËù°ïÖú£¬Ò²Ï£Íû´ó¼Ò¶à¶àÖ§³Ö¸ú°æÍø£¡