172 похожих чатов

Кто-Нибудь может сказать S_Access корректна (не имеет UB, безопасна, защищает

от гонок, алиасинга мут ссылок и ещё чего-то о чём я не знаю) для записи и чтения S?
Пожалуйста, не предлагайте мне других вариантов решения, не спрашивайте зачем мне это нужно и т. д.
Просто ответьте "да", "нет" или "не знаю". И если ответ "нет", то аргументируйте пожалуйста.

type T = ...;

static mut S: T = ...;
use S_local::S_Access;

mod S_local {
use core::ops::{DerefMut, Deref};
use core::sync::atomic::{AtomicBool, Ordering};
use core::marker::PhantomData;

pub struct S_Access(PhantomData<super::T>);

static IS_TAKEN: AtomicBool = AtomicBool::new(false);

impl S_Access {
pub fn take() -> Self {
IS_TAKEN.compare_exchange(false, true, Ordering::Acquire, Ordering::Acquire).unwrap();
Self(PhantomData)
}
}

impl Drop for S_Access {
fn drop(&mut self) {
IS_TAKEN.store(false, Ordering::Release);
}
}

impl Deref for S_Access {
type Target = super::T;

fn deref(&self) -> &Self::Target {
unsafe { &super::S }
}
}

impl DerefMut for S_Access {
fn deref_mut(&mut self) -> &mut Self::Target {
unsafe { &mut super::S }
}
}
}

10 ответов

21 просмотр

В чем толк от ответа "не знаю"

Kivooeo Terrors
В чем толк от ответа "не знаю"

не знаю - значит надо KANI брать

Андрей-Смирнов Автор вопроса

Если ты из двух тредов берёшь мутабельные ссылки на два разных инстанса S_Access, то по DerefMut получаешь две мутабельные ссылки на static mut.

Artem
Если ты из двух тредов берёшь мутабельные ссылки н...

Два разных не получится получить одновременно, ибо второй должен будет на атомике упасть.

1. Использование Acquire в compare_exchange значит, что запись будет Relaxed. 2. В исходниках spinlock делают SeqCst (ровно для тех же целей, в общем-то) https://docs.rs/spinlock/latest/src/spinlock/lib.rs.html#142 https://docs.rs/spinlock/latest/src/spinlock/lib.rs.html#189

Artem
1. Использование Acquire в compare_exchange значит...

Release-store синхронизируется с Acquire-load, Relaxed нужен только для failure ветки в compare_exchange(_weak)

Разве только для этого? Условно когда много потоков считают количество "хороших" чисел на промежутке, и инкрементируют один атомик, и им нафиг не нужна никакая синхронизация?

Андрей-Смирнов Автор вопроса

Может быть, ещё кто-нибудь знает ответ но не видел вопрос? Пока ещё не поступило достаточно утвердительного ответа.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта