¡¾¸´ÏÖ¡¿Chrome V8¶ÑɳÏäÈÆ¹ý¶ÈÎö
°ä²¼¹¦·ò 2025-04-301.×êÑв¼¾°
V8ÊÇGoogle Chrome¾ç±¾Ëµ»°£¨JavaScript£©µÄ½âÎöÒýÇæ¡£¶àÄêÀ´Google°²È«ÍŶÓÒ»ÏòÖÂÁ¦ÓÚÌáÉýV8µÄ°²È«ÐÔ£¬µ«V8·ì϶ÈÔ²ã³ö²»Çî¡£³ýÁ˾µäµÄÄÚ´æ·ÛËé¡¢ÔËÐÐʱÎÊÌ⣬V8ÓÅ»¯±àÒëÆ÷µÄÂß¼ÎÊÌâת»¯ÎªÄÚ´æ·ÛËéÊÇV8·ì϶ÖеĵäÐÍ¡£ÈôÊDZàÒëÆ÷×ÔÉí¾ÍÊǹ¥»÷Ãæ£¬ÌìÉúÓзì϶µÄ´úÂëÔÚËùδÃ⡣ͨ¹ý²ÉÈ¡Äڴ氲ȫµÄ±à³Ì˵»°»òÕßÓ²¼þ°²È«²»ÄÜ»º½âÕâÖÖÎÊÌâ¡£ÔÚÕâÖÖÇé¿öÏ£¬Google°²È«Ìá³öV8ɳÏ䣬½«V8¶Ñ±£ÁôÔÚ1TBµÄɳÏäÄÚ£¬½«ÀûÓÃV8·ì϶Ôì³ÉµÄ·ÛËéÏÞ¶ÈÔÚɳÏäÄÚ¡£¹¥»÷ÕßΪÁËÄܽøÒ»²½»ú¹ØËÁÒâÄÚ´æ¶Áд£¬±ØÐëÕÒµ½ÄÜÈÆ¹ýV8ɳÏäµÄ·ì϶¡£
ÃÎÏëÇé¿öÏ£¬V8ɳÏäʹµÃä¯ÀÀÆ÷¼´±ãÔËÐв»°²È«µÄ´úÂëÒ²²»»áÔì³É¹¥»÷Íþв¡£ È»¶øÊÂʵ²¢·ÇÈç´Ë¡£ÔÚpwn2own2024½ÇÖðÖУ¬Manfred PaulÀûÓÃÁËÒ»¸öV8ÖеÄÀàÐÍ»ìºÏ·ì϶£¨CVE-2024-2887£©½ÚÔìɳÏäÄÚµÄÄڴ棬ͬʱҲÅû¶ÁËÒ»ÖÖÈÆ¹ýV8ɳÏäµÄ²½Öè¡£GA»Æ½ð¼×ADLab×êÑÐÈËÔ±×ųÁ·ÖÎö¸´ÏÖÁ˸ÃV8ɳÏäµÄÈÆ¹ý²½Ö裬²¢ÌáÐÑGoogle ChromeÓû§ÊµÊ±¸üÐÂä¯ÀÀÆ÷£¬Ô¤·ÀÊܵ½NDayÍþв¡£
2.V8ɳÏä
V8ɳÏäµÄ³öÏÖ£¬½«¹ý³ÌµØÖ·¿Õ¼ä·ÖΪV8ɳÏäÄÚ´æºÍV8ɳÏä±íÄڴ棬ΪÁËÔ¤·ÀËÁÒâÄÚ´æ¶Áд£¬²»ÈÝʹÓÃΣÏÕµÄÔʼָÕ롣ɳÏäÄڵĶÔÏóͨ¹ý¶ÔɳÏä»ùµØÖ·µÄÆ«ÒÆÒýÓá£ÈçÏÂÃæµÄArrayBufferµÄÄÚ´æ²¼¾Ö£¬ºó¶Ë´æ´¢Êý¾ÝµÄÔʼָÕ루×ÏÉ«²¿ÃÅ£©ÓÉɳÏä»ùÖ·Æ«ÒÆÈ¡´ú£º

V8±í²¿¶ÔÏó£¨ÈçBlink¶ÔÏó£©Í¨¹ý±í²¿Ë÷Òý±íÒýÓá£ÎªÁ˽ÚÔìÁ÷ÆëÈ«ÐÔ£¬´úÂëºÍËüµÄÔªÊý¾ÝµÈΣÏÕ¶ÔÏóÒ²ÒªÒÆµ½É³Ïä±í£¬ÓÉ´úÂëË÷Òý±íÒÔ¼°ÐÅÀµ±íÒýÓá£ÐÅÀµ±íÓÃÓÚ¶Ô²»Ô̺¬ÔʼָÕëµÄV8¶ÔÏó£¨ÈçBytecode ¡¢Code metadata£©µÄË÷Òý£¬ÕâЩ¶ÔÏó¹ÌÈ»²»Ô̺¬Ö¸Õ룬µ«ÀûÓÃÕâЩ¶ÔÏóÈÔ¿ÉÄÜÍ»ÆÆÉ³Ïä¡£V8ɳÏäÕûÌåµÄÉè¼ÆÍ¼ÈçÏ£º

V8ɳÏäµÄ³öÏÖÔö³¤ÁËÀûÓÃÁ´µÄ³¤¶È£¬¿Ï¶¨Ë®Æ½ÉÏÏ÷¼õÁËV8·ì϶¶Ôä¯ÀÀÆ÷°²È«´øÀ´µÄ¹¥»÷Íþв¡£¹¥·ÀÏàÉúÏà¿Ë£¬ÔÚpwn2own2024½ÇÖðÖУ¬Manfred Paul¾ÍÀûÓÃÒ»¸öÕûÊýÒç¶Âí½ÅÈÆ¹ýÁËV8ɳÏä¡£
3.·ì϶·ÖÎö
ÔÚɳÏä³öÏÖǰ£¬Í¨¹ýArrayBufferÒÔ¼°Æä¶ÔÓ¦µÄTypedArrayºó¶Ë´æ´¢¿ÉÓÐЧ½ÚÔìËÁÒâÄÚ´æ¶Áд¡£´ÓÉÏÃæµÄArrayBufferµÄÄÚ´æ²¼¾Ö¿ÉÖª£¬´Ë¿Ìºó¶Ë´æ´¢Ö¸Õë±»´úÌæÎªÉ³ÏäÖ¸Õ룬²¢ÇÒ³¤¶È±»ÏÞ¶ÈÔÚ235 £¬ÓÐЧ×èÖ¹ÁËÀûÓÃÕâÖÖ²½ÖèËÁÒâ¶Áд¡£
Ëæ×ÅResizable ArrayBufferµÄ³öÏÖ£¬¶ÔArrayBufferºÍSharedArrayBufferÒÔ¼°ËûÃǵÄType ViewµÄ½Ó¼û±äµÃÔ½·¢¸´ÔÓ¡£¾ßÌåÀ´½²¶ÔÓÚArrayBufferºÍSharedArrayBufferµÄ»ú¹Øº¯ÊýÔö³¤ÁËmaximum length£¬ArrayBuffer¿ÉÄÜËæÊ±Ôö³¤ºÍËõ¼õ»º´æ´óÓ×£¬¶øSharedArraybuffer¿ÉÄÜËæÊ±Ôö³¤»º´æ´óÓס£ÔÚ¶ÔÏó´´½¨ºó»º´æµÄ¶¯Ì¬±ä¶¯£¬ÒÔÖÁÿ´Î½Ó¼ûºó¶Ë»º´æ¶¼Òª³ÁÐÂÍÆË㻺´æµÄ³¤¶È¡£

¶ÔÓÚÀàÐÍÊý×éµÄ³¤¶ÈÍÆËãÓ¦¸Ã²ÉÈ¡£¨byte_length - byte_offset£©/element_size , ÏÂÃæÊǶÔRAB³¤¶ÈÍÆË㣺

Ïà½ÏÓÚRAB¶ÔÓÚbyte_lengthºÍbyte_offsetµÄÒç³ö²é³£¬GSAB¶ÌȱÕûÊýÒç³ö²é³£¬ÔÚÕ¼ÓÐɳÏäÄÚÄÚ´æ·ÛËéµÄÄÜÁ¦Ï£¬ÕâÁ½¸öÖµÆëÈ«¿É¿Ø£¬µ±byte_offset´óÓÚbyte_length, Æäºó¶Ë´æ´¢ºóµÄÕû¸öµØÖ·¿Õ¼ä¿É¿Ø£¬ÆëÈ«Í»ÆÆV8ɳÏ䣬´ïµ½É³Ïä±íÄÚ´æ¶Áд¡£

4.·ì϶¸´ÏÖ
´´½¨GSAB (ab)¶ÔÏó£¬lengthΪ0x3000£¬maxByteLengthΪ0x6000£»´´½¨ÀàÐÍÊý×éUint8Array (dv)£¬Æ«ÒÆÖµÎª0x2000 £»ÓÅ»¯funcº¯Êýƾ¾ÝÌṩµÄË÷Òý£¨i£©¸øÀàÐÍÊý×éÔªËØ£¨dv[i]£©¸³Öµ£¨0x88£©¡£
´òÓ¡ÀàÐÍÊý×é¶ÔÏó£¨dv£©ÒÔ±ãÓڲ鿴Æäºó¶Ë´æ´¢Ö¸Õ룬ʹÓÃɳÏäÄÚдº¯ÊýÅú¸ÄÀàÐÍÊý×飨dv£©µÄÆ«ÒÆÎª0x8000£¨ÓÉÓÚÄÚ´æ´æ´¢ÕûÊýֵΪÏÖʵֵµÄ2±¶£¬ËùÒÔÏÖÊµÆ«ÒÆÎª0x4000 £©¡£Æ«ÒÆÖµ£¨0x4000£©´óÓÚ³¤¶È(0x3000) ,µ¼ÖÂÕûÊýÒç³ö£¬µ±Ê¹Óó¬´óµÄË÷Òý£¨0x10000000000£©Ô½½ç½Ó¼ûºó¶Ë»º´æÊ±£¬ÍÆËãµÄË÷ÒýÓ×ÓÚ³¤¶ÈÖµ£¬µ¼ÖÂÔ½½çд¡£
Äܹ»¿´µ½ÀàÐÍÊý×飨dv£©µÄºó¶Ë´æ´¢Ö¸ÕëΪ0x316600002000£º

V8ɳÏäµÄÄÚ´æÁìÓòÊÇÔÚ1TBµÄµØÖ·¿Õ¼ä£¬·¨Ê½ÔÚ¶Ô0x326600002000ɳÏä±íµÄ²»³ÉдÄڴ渳ֵ£¨0x88£©Ê±³öÏÖ±ÀÀ££º


5.·ì϶½¨¸´

6.·ì϶ӰÏì
Chrome before 123.0.6312.86
[1]https://docs.google.com/document/d/1FM4fQmIhEqPG8uGp5o9A-mnPB5BOeScZYpkHjo0KKA8/edit?tab=t.0
[2]https://www.zerodayinitiative.com/blog/2024/5/2/cve-2024-2887-a-pwn2own-winning-bug-in-google-chrome
[3]https://github.com/tc39/proposal-resizablearraybuffer
[4]https://chromium-review.googlesource.com/c/v8/v8/+/5385329/4/src/compiler/graph-assembler.cc
GA»Æ½ð¼×»ý¼«·ÀÓù³¢ÊÔÊÒ£¨ADLab£©
ADLab³ÉÁ¢ÓÚ1999Ä꣬ÊÇÖйú°²È«ÐÐÒµ×îÔç³ÉÁ¢µÄ¹¥·À¼¼Êõ×êÑг¢ÊÔÊÒÖ®Ò»£¬Î¢ÈíMAPP´òËãÖ÷Ìâ³ÉÔ±£¬¡°ºÚȸ¹¥»÷¡±¸ÅÏëÊ×ÍÆÕß¡£½ØÖÁĿǰ£¬ADLabÒÑͨ¹ý CNVD/CNNVD/NVDB/CVEÀۼư䲼°²È«·ì϶6500Óà¸ö£¬³ÖÐøÎ¬³Ö¹ú¼ÊÍøÂ簲ȫÁìÓòÒ»Á÷Ë®×¼¡£³¢ÊÔÊÒ×êÑз½Ïòº¸Ç»ù´¡°²È«×êÑÓ×¢Êý¾Ý°²È«×êÑÓ×¢5G°²È«×êÑÓ×¢AI+°²È«×êÑÓ×¢ÎÀÐǰ²È«×êÑÓ×¢ÔËÓªÉÌ»ù´¡ÉèÊ©°²È«×êÑÓ×¢ÒÆ¶¯°²È«×êÑÓ×¢ÎïÁªÍø°²È«×êÑÓ×¢³µÁªÍø°²È«×êÑÓ×¢¹¤¿Ø°²È«×êÑÓ×¢ÐÅ´´°²È«×êÑÓ×¢ÔÆ°²È«×êÑÓ×¢ÎÞÏß°²È«×êÑÓ×¢¸ß¼¶Íþв×êÑÓ×¢¹¥·ÀÆ¥µÐ¼¼Êõ×êÑС£×êÑгɾÍÀûÓÃÓÚ²úÆ·Ö÷Ìâ¼¼Êõ×êÑÓ×¢¹ú¶È³Áµã¿Æ¼¼ÏîÄ¿¹¥¹Ø¡¢×¨Òµ°²È«·þÎñµÈ¡£



¾©¹«Íø°²±¸11010802024551ºÅ