сейчас все процессоры, где у каждого ядра свой кэш используют протокол MOESI?
вбиваешь в поискович модель процессора и заходишь на сайт производителя
вот как пример https://www.intel.ru/content/www/ru/ru/products/sku/134599/intel-core-i912900k-processor-30m-cache-up-to-5-20-ghz/specifications.html
ну,там нет нужной мне информации)))в общем,ладно,может я не то гуглю
а какую инфу ищешь?
ну вот я лекцию смотрел,тут устройство процессора объясняют и рассказывают про очередь и какой-то брокер(на фотке в середине круглый),там дальше про некоторые ложные абстракции,которые приводят к вылету программы(пытался воспроизвести не получилось),ну и мне стало интересно каким образом ядра между собой общаются,что за брокер и как обходят проблему с очередью(потому что процессор смотрит запросы в неё,только когда у него время появляется)
Такого ты не найдёшь, это как попросить исходный код коммерческого ПО у разработчиков... Разве что ревёрс-инжиниринг очень старого процессора, там всё это расписано будет Но, опять же, это незаконно. И то, вроде, ревёрс делают только потому, что лицензию сняли
Тебя интересует, как процессор синхронизирует между собой ядра, или что конкретно?
Ну, для начала да,я по сути понял, что там протокол MOESI используется, чтобы линии кэша ядер синхронизировать, но во всех ли процессорах это используется мне интересно и что за брокер, который помогает ядрам общаться Я понимаю, что незаконно, искал у АМД,но тоже ничего нет, вдруг просто какие-нибудь старые процы открыты, например,FXы
Ну, судя по картинке, брокер это и есть тот самый элемент MOESI, через который ядра уведомляют о состоянии кэш-линии, при этом помогая избежать обратной записи в RAM
По поводу "во всех ли процессорах MOESI" - нет, не всегда. Помимо него есть ещё MESI, MESIF, MOSI ARM11 использует MESI Но ARM Cortex-A57 использует MESI на L1 и MOESI в L2 Потому что MOESI превосходит MESI по производительности, но у MESI = 2 бита на строку кэша для состояний, а у MOESI = 3 бита. Поэтому для меньших строк кэша расходы MOESI увеличиваются, это не всегда оправдано, если с ним происходит мало операций записи в строки кэша. Поэтому MOESI будет менее эффективным по производительности на джоуль\ватт Подробнее про кэши MOESI, MESI и MESIF прочитай на вики И вот ещё нашёл краткий разбор, в каких процессорах (а точнее, микроархитектурах) AMD и Intel какие использовались протоколы когерентности кэша https://expertiza.csc.ncsu.edu/index.php/CSC/ECE_506_Spring_2010/8a_sk И насчёт синхронизации ядер тебе нужно читать про технологию Hyper-Threading от Intel, по ней тоже много информации, в том числе на Wikipedia
Наверное,просто было сказано,что он как-то сообщения между ядрами передаёт,точнее от одной очереди ядра другой
Да, это и имелось ввиду. broker = "посредник" Ибо я сам удивился, ничего не нашёл по этому поводу. Нет никакого брокера. Значит, скорее всего, это просто обозначение передачи состояний
О,вот это интереснее,спасибо Ну,на Вике я находил и спекулятивное исполнение, не сказать что там развёрнуто написано)
Мне сначала казалось, что это какой-то блок,который использует механизм MOESI,видимо это просто абстракция для понимания,ладно
Обсуждают сегодня