[Tarantool-patches] [PATCH luajit v3 1/2] snap: check J->pc is within its proto bytecode

Sergey Bronnikov sergeyb at tarantool.org
Sun Nov 26 18:12:31 MSK 2023


Hi, Maxim


LGTM

On 10/4/23 15:50, Maksim Kokryashkin wrote:
> From: Mike Pall <mike>
>
> (cherry-picked from commit 5c46f47736f7609be407c88d531ecd1689d40a79)
>
> This commit adds an assertion to ensure that the `pc` of the
> snapshot being made is located within the current prototype.
> Violation of this assertion's condition may lead to all kinds
> of buggy behavior on restoration from that snapshot, depending
> on what is located in memory at the address under `pc`.
>
> NOTICE: This patch is only a part of the original commit,
> and the other part is backported in the following commit. The
> patch was split into two, so the test case becomes easier to
> implement since it can now depend on this assertion instead
> of memory layout.
>
> Maxim Kokryashkin:
> * added the description for the problem
>
> Part of tarantool/tarantool#9145
> ---
>   src/lj_snap.c | 3 +++
>   1 file changed, 3 insertions(+)
>
> diff --git a/src/lj_snap.c b/src/lj_snap.c
> index 6c5e5e53..3f0fccec 100644
> --- a/src/lj_snap.c
> +++ b/src/lj_snap.c
> @@ -115,6 +115,9 @@ static MSize snapshot_framelinks(jit_State *J, SnapEntry *map, uint8_t *topslot)
>   #else
>     MSize f = 0;
>     map[f++] = SNAP_MKPC(J->pc);  /* The current PC is always the first entry. */
> +  lj_assertJ(!J->pt ||
> +	     (J->pc >= proto_bc(J->pt) &&
> +	      J->pc < proto_bc(J->pt) + J->pt->sizebc), "bad snapshot PC");
>   #endif
>     while (frame > lim) {  /* Backwards traversal of all frames above base. */
>       if (frame_islua(frame)) {


More information about the Tarantool-patches mailing list