Hacker News new | ask | show | jobs
by Arnavion 1995 days ago
>The comment for the take method claims that put and take can be called be concurrently with each other. But both call get() on an UnsafeCell.

They can be called concurrently with each other, but the call to `UnsafeCell::get()` is guarded by an acquire-release latch for precisely that reason. This is already explained in the article.

>I'm scratching my head on the syntax. There is no read() method on MaybeUninit. Also, the type passed to the write() method is wrong. I need to clone this and see if I can compile this.

read() and write() are functions of `*mut T`, which is what is returned by `UnsafeCell::get()`

1 comments

I don't know that synchronizing with acquire-release is enough to make LLVM happy in this case. Mutable references are tagged with the LLVM noalias attribute. Rust language folks are very adamant about how wrong it is to end up with multiple aliases tagged with noalias. This is playing with fire.
There are no multiple aliases in the code presented in the blog post.
Ok you are right.
Also UnsafeCell’s purpose in life is to make sure noalias is removed where appropriate.
Can you explain that more? Because the requirement I pasted about having unique aliases does come from the UnsafeCell documentation. My understanding is that &mut still needs to be a unique alias even when it comes from an UnsafeCell.
>My understanding is that &mut still needs to be a unique alias even when it comes from an UnsafeCell.

That is correct. steveklabnik was not talking about this.

UnsafeCell needs to prevent optimizations that reorder accesses to the `&mut` derived from its `*mut`. If reordering was allowed it could be possible that you write code that creates two `&mut` (or one `&mut` and one `&`) that appear to have distinct lifetimes (which ought to be well-defined) but are nevertheless reordered by the optimizer to overlap (which is aliasing, and thus UB).

It also needs to disable the assumption that a `&Foo` is immutable if `Foo` is `UnsafeCell` or an aggregate that transitively contains `UnsafeCell`.

This special behavior is why UnsafeCell is a lang item.