Commit 422dc378 authored by Ray Wang's avatar Ray Wang Committed by V8 LUCI CQ

[deserialization] Remove unnecessarily limit on buffer size

1. Now there is no serializer/deserializer-specific buffer size limit.
2. Update AUTHORS

Ref: https://github.com/nodejs/node/issues/40059

Change-Id: Iad4c6d8f68a91ef21d3c404fb7945949e69ad9e2
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3170411Reviewed-by: 's avatarJakob Kummerow <jkummerow@chromium.org>
Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
Commit-Queue: Jakob Kummerow <jkummerow@chromium.org>
Cr-Commit-Position: refs/heads/main@{#77084}
parent bd87901c
...@@ -57,13 +57,12 @@ Alexis Campailla <alexis@janeasystems.com> ...@@ -57,13 +57,12 @@ Alexis Campailla <alexis@janeasystems.com>
Allan Sandfeld Jensen <allan.jensen@qt.io> Allan Sandfeld Jensen <allan.jensen@qt.io>
Amos Lim <eui-sang.lim@samsung.com> Amos Lim <eui-sang.lim@samsung.com>
Andreas Anyuru <andreas.anyuru@gmail.com> Andreas Anyuru <andreas.anyuru@gmail.com>
Andrew Paprocki <andrew@ishiboo.com>
Andrei Kashcha <anvaka@gmail.com> Andrei Kashcha <anvaka@gmail.com>
Andrew Paprocki <andrew@ishiboo.com>
Anna Henningsen <anna@addaleax.net> Anna Henningsen <anna@addaleax.net>
Antoine du Hamel <duhamelantoine1995@gmail.com> Antoine du Hamel <duhamelantoine1995@gmail.com>
Anton Bikineev <ant.bikineev@gmail.com> Anton Bikineev <ant.bikineev@gmail.com>
Bangfu Tao <bangfu.tao@samsung.com> Bangfu Tao <bangfu.tao@samsung.com>
Daniel Shelton <d1.shelton@samsung.com>
Ben Coe <bencoe@gmail.com> Ben Coe <bencoe@gmail.com>
Ben Newman <ben@meteor.com> Ben Newman <ben@meteor.com>
Ben Noordhuis <info@bnoordhuis.nl> Ben Noordhuis <info@bnoordhuis.nl>
...@@ -74,7 +73,6 @@ Brice Dobry <brice.dobry@futurewei.com> ...@@ -74,7 +73,6 @@ Brice Dobry <brice.dobry@futurewei.com>
Burcu Dogan <burcujdogan@gmail.com> Burcu Dogan <burcujdogan@gmail.com>
Caitlin Potter <caitpotter88@gmail.com> Caitlin Potter <caitpotter88@gmail.com>
Chao Wang <chao.w@rioslab.org> Chao Wang <chao.w@rioslab.org>
Craig Schlenter <craig.schlenter@gmail.com>
Charles Kerr <charles@charleskerr.com> Charles Kerr <charles@charleskerr.com>
Chengzhong Wu <legendecas@gmail.com> Chengzhong Wu <legendecas@gmail.com>
Choongwoo Han <cwhan.tunz@gmail.com> Choongwoo Han <cwhan.tunz@gmail.com>
...@@ -82,10 +80,12 @@ Chris Nardi <hichris123@gmail.com> ...@@ -82,10 +80,12 @@ Chris Nardi <hichris123@gmail.com>
Christopher A. Taylor <chris@gameclosure.com> Christopher A. Taylor <chris@gameclosure.com>
Colin Ihrig <cjihrig@gmail.com> Colin Ihrig <cjihrig@gmail.com>
Cong Zuo <zckevinzc@gmail.com> Cong Zuo <zckevinzc@gmail.com>
Craig Schlenter <craig.schlenter@gmail.com>
Daniel Andersson <kodandersson@gmail.com> Daniel Andersson <kodandersson@gmail.com>
Daniel Bevenius <daniel.bevenius@gmail.com> Daniel Bevenius <daniel.bevenius@gmail.com>
Daniel Dromboski <dandromb@gmail.com> Daniel Dromboski <dandromb@gmail.com>
Daniel James <dnljms@gmail.com> Daniel James <dnljms@gmail.com>
Daniel Shelton <d1.shelton@samsung.com>
Darshan Sen <raisinten@gmail.com> Darshan Sen <raisinten@gmail.com>
David Carlier <devnexen@gmail.com> David Carlier <devnexen@gmail.com>
David Manouchehri <david@davidmanouchehri.com> David Manouchehri <david@davidmanouchehri.com>
...@@ -120,13 +120,13 @@ Ingvar Stepanyan <me@rreverser.com> ...@@ -120,13 +120,13 @@ Ingvar Stepanyan <me@rreverser.com>
Ioseb Dzmanashvili <ioseb.dzmanashvili@gmail.com> Ioseb Dzmanashvili <ioseb.dzmanashvili@gmail.com>
Isiah Meadows <impinball@gmail.com> Isiah Meadows <impinball@gmail.com>
Jaime Bernardo <jaime@janeasystems.com> Jaime Bernardo <jaime@janeasystems.com>
Jan de Mooij <jandemooij@gmail.com> James M Snell <jasnell@gmail.com>
James Pike <g00gle@chilon.net>
Jan Krems <jan.krems@gmail.com> Jan Krems <jan.krems@gmail.com>
Jan de Mooij <jandemooij@gmail.com>
Janusz Majnert <jmajnert@gmail.com> Janusz Majnert <jmajnert@gmail.com>
Jay Freeman <saurik@saurik.com>
James Pike <g00gle@chilon.net>
James M Snell <jasnell@gmail.com>
Javad Amiri <javad.amiri@anu.edu.au> Javad Amiri <javad.amiri@anu.edu.au>
Jay Freeman <saurik@saurik.com>
Jesper van den Ende <jespertheend@gmail.com> Jesper van den Ende <jespertheend@gmail.com>
Ji Qiu <qiuji@iscas.ac.cn> Ji Qiu <qiuji@iscas.ac.cn>
Jianghua Yang <jianghua.yjh@alibaba-inc.com> Jianghua Yang <jianghua.yjh@alibaba-inc.com>
...@@ -136,8 +136,8 @@ Joel Stanley <joel@jms.id.au> ...@@ -136,8 +136,8 @@ Joel Stanley <joel@jms.id.au>
Johan Bergström <johan@bergstroem.nu> Johan Bergström <johan@bergstroem.nu>
Jonathan Liu <net147@gmail.com> Jonathan Liu <net147@gmail.com>
Julien Brianceau <jbriance@cisco.com> Julien Brianceau <jbriance@cisco.com>
Junha Park <jpark3@scu.edu>
JunHo Seo <sejunho@gmail.com> JunHo Seo <sejunho@gmail.com>
Junha Park <jpark3@scu.edu>
Junming Huang <kiminghjm@gmail.com> Junming Huang <kiminghjm@gmail.com>
Kang-Hao (Kenny) Lu <kennyluck@csail.mit.edu> Kang-Hao (Kenny) Lu <kennyluck@csail.mit.edu>
Karl Skomski <karl@skomski.com> Karl Skomski <karl@skomski.com>
...@@ -181,20 +181,21 @@ Oleksandr Chekhovskyi <oleksandr.chekhovskyi@gmail.com> ...@@ -181,20 +181,21 @@ Oleksandr Chekhovskyi <oleksandr.chekhovskyi@gmail.com>
Oliver Dunk <oliver@oliverdunk.com> Oliver Dunk <oliver@oliverdunk.com>
Paolo Giarrusso <p.giarrusso@gmail.com> Paolo Giarrusso <p.giarrusso@gmail.com>
Patrick Gansterer <paroga@paroga.com> Patrick Gansterer <paroga@paroga.com>
Paul Lind <plind44@gmail.com>
Pavel Medvedev <pmedvedev@gmail.com>
Peng Fei <pfgenyun@gmail.com> Peng Fei <pfgenyun@gmail.com>
Peng Wu <peng.w@rioslab.org> Peng Wu <peng.w@rioslab.org>
Peng-Yu Chen <pengyu@libstarrify.so> Peng-Yu Chen <pengyu@libstarrify.so>
Peter Rybin <peter.rybin@gmail.com> Peter Rybin <peter.rybin@gmail.com>
Peter Varga <pvarga@inf.u-szeged.hu> Peter Varga <pvarga@inf.u-szeged.hu>
Peter Wong <peter.wm.wong@gmail.com> Peter Wong <peter.wm.wong@gmail.com>
Paul Lind <plind44@gmail.com>
Pavel Medvedev <pmedvedev@gmail.com>
PhistucK <phistuck@gmail.com> PhistucK <phistuck@gmail.com>
Qingyan Li <qingyan.liqy@alibaba-inc.com> Qingyan Li <qingyan.liqy@alibaba-inc.com>
Qiuyi Zhang <qiuyi.zqy@alibaba-inc.com> Qiuyi Zhang <qiuyi.zqy@alibaba-inc.com>
Rafal Krypa <rafal@krypa.net> Rafal Krypa <rafal@krypa.net>
Raul Tambre <raul@tambre.ee> Raul Tambre <raul@tambre.ee>
Ray Glover <ray@rayglover.net> Ray Glover <ray@rayglover.net>
Ray Wang <ray@isrc.iscas.ac.cn>
Refael Ackermann <refack@gmail.com> Refael Ackermann <refack@gmail.com>
Rene Rebe <rene@exactcode.de> Rene Rebe <rene@exactcode.de>
Reza Yazdani <ryazdani@futurewei.com> Reza Yazdani <ryazdani@futurewei.com>
...@@ -219,11 +220,13 @@ Stefan Penner <stefan.penner@gmail.com> ...@@ -219,11 +220,13 @@ Stefan Penner <stefan.penner@gmail.com>
Stephan Hartmann <stha09@googlemail.com> Stephan Hartmann <stha09@googlemail.com>
Stephen Belanger <stephen.belanger@datadoghq.com> Stephen Belanger <stephen.belanger@datadoghq.com>
Sylvestre Ledru <sledru@mozilla.com> Sylvestre Ledru <sledru@mozilla.com>
Takeshi Yoneda <takeshi@tetrate.io>
Taketoshi Aono <brn@b6n.ch> Taketoshi Aono <brn@b6n.ch>
Tao Liqiang <taolq@outlook.com> Tao Liqiang <taolq@outlook.com>
Teddy Katz <teddy.katz@gmail.com> Teddy Katz <teddy.katz@gmail.com>
Thomas Young <wenzhang5800@gmail.com> Thomas Young <wenzhang5800@gmail.com>
Tiancheng "Timothy" Gu <timothygu99@gmail.com> Tiancheng "Timothy" Gu <timothygu99@gmail.com>
Tianping Yang <yangtianping@oppo.com>
Timo Teräs <timo.teras@iki.fi> Timo Teräs <timo.teras@iki.fi>
Tobias Burnus <burnus@net-b.de> Tobias Burnus <burnus@net-b.de>
Tobias Nießen <tniessen@tnie.de> Tobias Nießen <tniessen@tnie.de>
...@@ -248,13 +251,11 @@ Yi Wang <wangyi8848@gmail.com> ...@@ -248,13 +251,11 @@ Yi Wang <wangyi8848@gmail.com>
Yong Wang <ccyongwang@tencent.com> Yong Wang <ccyongwang@tencent.com>
Youfeng Hao <ajihyf@gmail.com> Youfeng Hao <ajihyf@gmail.com>
Yu Yin <xwafish@gmail.com> Yu Yin <xwafish@gmail.com>
Yusif Khudhur <yusif.khudhur@gmail.com>
Yuri Iozzelli <yuri@leaningtech.com> Yuri Iozzelli <yuri@leaningtech.com>
Yusif Khudhur <yusif.khudhur@gmail.com>
Zac Hansen <xaxxon@gmail.com> Zac Hansen <xaxxon@gmail.com>
Zeynep Cankara <zeynepcankara402@gmail.com> Zeynep Cankara <zeynepcankara402@gmail.com>
Zhao Jiazhong <kyslie3100@gmail.com> Zhao Jiazhong <kyslie3100@gmail.com>
Zheng Liu <i6122f@gmail.com> Zheng Liu <i6122f@gmail.com>
Zhongping Wang <kewpie.w.zp@gmail.com> Zhongping Wang <kewpie.w.zp@gmail.com>
柳荣一 <admin@web-tinker.com> 柳荣一 <admin@web-tinker.com>
Tianping Yang <yangtianping@oppo.com>
Takeshi Yoneda <takeshi@tetrate.io>
...@@ -3369,7 +3369,6 @@ struct ValueDeserializer::PrivateData { ...@@ -3369,7 +3369,6 @@ struct ValueDeserializer::PrivateData {
: isolate(i), deserializer(i, data, delegate) {} : isolate(i), deserializer(i, data, delegate) {}
i::Isolate* isolate; i::Isolate* isolate;
i::ValueDeserializer deserializer; i::ValueDeserializer deserializer;
bool has_aborted = false;
bool supports_legacy_wire_format = false; bool supports_legacy_wire_format = false;
}; };
...@@ -3379,16 +3378,8 @@ ValueDeserializer::ValueDeserializer(Isolate* isolate, const uint8_t* data, ...@@ -3379,16 +3378,8 @@ ValueDeserializer::ValueDeserializer(Isolate* isolate, const uint8_t* data,
ValueDeserializer::ValueDeserializer(Isolate* isolate, const uint8_t* data, ValueDeserializer::ValueDeserializer(Isolate* isolate, const uint8_t* data,
size_t size, Delegate* delegate) { size_t size, Delegate* delegate) {
if (base::IsValueInRangeForNumericType<int>(size)) { private_ = new PrivateData(reinterpret_cast<i::Isolate*>(isolate),
private_ = new PrivateData( base::Vector<const uint8_t>(data, size), delegate);
reinterpret_cast<i::Isolate*>(isolate),
base::Vector<const uint8_t>(data, static_cast<int>(size)), delegate);
} else {
private_ =
new PrivateData(reinterpret_cast<i::Isolate*>(isolate),
base::Vector<const uint8_t>(nullptr, 0), nullptr);
private_->has_aborted = true;
}
} }
ValueDeserializer::~ValueDeserializer() { delete private_; } ValueDeserializer::~ValueDeserializer() { delete private_; }
...@@ -3398,15 +3389,6 @@ Maybe<bool> ValueDeserializer::ReadHeader(Local<Context> context) { ...@@ -3398,15 +3389,6 @@ Maybe<bool> ValueDeserializer::ReadHeader(Local<Context> context) {
ENTER_V8_NO_SCRIPT(isolate, context, ValueDeserializer, ReadHeader, ENTER_V8_NO_SCRIPT(isolate, context, ValueDeserializer, ReadHeader,
Nothing<bool>(), i::HandleScope); Nothing<bool>(), i::HandleScope);
// We could have aborted during the constructor.
// If so, ReadHeader is where we report it.
if (private_->has_aborted) {
isolate->Throw(*isolate->factory()->NewError(
i::MessageTemplate::kDataCloneDeserializationError));
has_pending_exception = true;
RETURN_ON_FAILED_EXECUTION_PRIMITIVE(bool);
}
bool read_header = false; bool read_header = false;
has_pending_exception = !private_->deserializer.ReadHeader().To(&read_header); has_pending_exception = !private_->deserializer.ReadHeader().To(&read_header);
RETURN_ON_FAILED_EXECUTION_PRIMITIVE(bool); RETURN_ON_FAILED_EXECUTION_PRIMITIVE(bool);
...@@ -3430,12 +3412,10 @@ void ValueDeserializer::SetSupportsLegacyWireFormat( ...@@ -3430,12 +3412,10 @@ void ValueDeserializer::SetSupportsLegacyWireFormat(
} }
uint32_t ValueDeserializer::GetWireFormatVersion() const { uint32_t ValueDeserializer::GetWireFormatVersion() const {
CHECK(!private_->has_aborted);
return private_->deserializer.GetWireFormatVersion(); return private_->deserializer.GetWireFormatVersion();
} }
MaybeLocal<Value> ValueDeserializer::ReadValue(Local<Context> context) { MaybeLocal<Value> ValueDeserializer::ReadValue(Local<Context> context) {
CHECK(!private_->has_aborted);
PREPARE_FOR_EXECUTION(context, ValueDeserializer, ReadValue, Value); PREPARE_FOR_EXECUTION(context, ValueDeserializer, ReadValue, Value);
i::MaybeHandle<i::Object> result; i::MaybeHandle<i::Object> result;
if (GetWireFormatVersion() > 0) { if (GetWireFormatVersion() > 0) {
...@@ -3452,14 +3432,12 @@ MaybeLocal<Value> ValueDeserializer::ReadValue(Local<Context> context) { ...@@ -3452,14 +3432,12 @@ MaybeLocal<Value> ValueDeserializer::ReadValue(Local<Context> context) {
void ValueDeserializer::TransferArrayBuffer(uint32_t transfer_id, void ValueDeserializer::TransferArrayBuffer(uint32_t transfer_id,
Local<ArrayBuffer> array_buffer) { Local<ArrayBuffer> array_buffer) {
CHECK(!private_->has_aborted);
private_->deserializer.TransferArrayBuffer(transfer_id, private_->deserializer.TransferArrayBuffer(transfer_id,
Utils::OpenHandle(*array_buffer)); Utils::OpenHandle(*array_buffer));
} }
void ValueDeserializer::TransferSharedArrayBuffer( void ValueDeserializer::TransferSharedArrayBuffer(
uint32_t transfer_id, Local<SharedArrayBuffer> shared_array_buffer) { uint32_t transfer_id, Local<SharedArrayBuffer> shared_array_buffer) {
CHECK(!private_->has_aborted);
private_->deserializer.TransferArrayBuffer( private_->deserializer.TransferArrayBuffer(
transfer_id, Utils::OpenHandle(*shared_array_buffer)); transfer_id, Utils::OpenHandle(*shared_array_buffer));
} }
......
...@@ -1120,7 +1120,7 @@ ValueDeserializer::ValueDeserializer(Isolate* isolate, ...@@ -1120,7 +1120,7 @@ ValueDeserializer::ValueDeserializer(Isolate* isolate,
: isolate_(isolate), : isolate_(isolate),
delegate_(delegate), delegate_(delegate),
position_(data.begin()), position_(data.begin()),
end_(data.begin() + data.length()), end_(data.end()),
id_map_(isolate->global_handles()->Create( id_map_(isolate->global_handles()->Create(
ReadOnlyRoots(isolate_).empty_fixed_array())) {} ReadOnlyRoots(isolate_).empty_fixed_array())) {}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment