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 ответов

7 просмотров

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

Albert 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)

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

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

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

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

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

Доброй ночи. Вопрос знатокам. Имеется некая таблица, результат которой выведен в DBGrid на форме. И есть форма, с помощью которой можно как добавить запись, так и отредактиров...
Евгений
27
а всё почему? потому что ассемблер в отличии от яву порождает множество пагубных привычек, среди которых например можно отметить использование глобальных переменных для всего ...
Mixail Frolov
35
анрей С какой целью зашёл?
КТ315
42
Кто нибудь из участников чата пишет на ассемблере под GNU/Linux?
Spiker01
24
я часов 15 назад начал пытаться написать хоть что-то напоминающее ос и у меня есть проблема, которую я пытаюсь решить последние часов 5: есть крч 2 исходника с минимальным код...
Al1to
17
Всем привет ребят! Мб кто-то сталкивался? adminСomponents .get("searchСomponents", use: searchComponents) .openAPI( summary: ...
Admin Adminov
2
Кстати вопрос. Проанализировав свои проекты я понял, что в наиболее ценных из них Асм использовался для организации real-time процессов (внутри DOS). А какие есть способы сего...
Alexander Morozov
18
Я не очень много работал с потоками, тут возник вопрос - если будет одновременный доступ к памяти из двух разных потоков, это само по себе приведет к ошибке?
The Bird of Hermes
25
Насколько моя реализация Exercise 1 плохая? data MessageType = Info | Warning | Error Int deriving (Show, Eq) type TimeStamp = Int data LogMessage = LogMessage ...
= ?
6
а вот интересный вопрос появляется: допустим у нас есть приложение с системой модулей. Будет ли считаться система модуль+прога ассемблерной программой если: а) Прога на Си, м...
Mixail Frolov
29
Карта сайта