HomePhabricator
Diffusion Comm bfa33b823085

[native] Avoid pointer to other parts of class

Description

[native] Avoid pointer to other parts of class

Summary:
I initially made this change hoping it would fully fix ENG-5354. Unfortunately it didn't, and the reasons are described here. That said, I still think it's a good idea to make this change, so I'm submitting it for review.

Olm library background

When calling [olm_account](https://github.com/CommE2E/olm/blob/6d0eaa993257225faf62768c898fe090fcc2dd2d/src/olm.cpp#L180) to construct an OlmAccount, you pass in the buffer (a pointer to memory) where the OlmAccount can be constructed. It's done this way because the Olm team does not want to handle memory management, and as such requires the caller to allocate the memory.

That means that the pointer returned by olm_account is exactly the same as the pointer passed to it. olm_account constructs the object at that memory location, and then returns you that same pointer cast as the specified type.

Our use

In our case, the accountBuffer is a member of CryptoModule. When we pass a pointer to accountBuffer to olm_account, we get that same buffer back, which we then assign to another member of CryptoModule, account.

The result is that if CryptoModule is constructed on the stack, account is a pointer to the stack.

This is "non-standard" behavior in C++. You generally don't want pointers to the stack. Crucially, in our case, this breaks assumptions that the default implicit copy constructor in C++ has.

The implicit copy constructor sees a pointer, assumes it points to the heap, and just copies it. This is bad for us, since we get a pointer pointing to space on the stack that quickly gets deallocated.

Solution

Instead of storing the pointer, we can just call accountBuffer->data() to get it.

Test Plan: I made sure notifs still worked in my local environment (iOS simulator running dev build, along with keyserver connected to APNs in dev mode)

Reviewers: marcin, tomek, bartek, atul

Reviewed By: marcin

Subscribers: wyilio

Differential Revision: https://phab.comm.dev/D9559

Details

Provenance
ashoatAuthored on Oct 20 2023, 11:19 PM
Reviewer
marcin
Differential Revision
D9559: [native] Avoid pointer to other parts of class
Parents
rCOMMa689d2faedcc: [lib] Remove setCookieOnRequest
Branches
Unknown
Tags
Unknown