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

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

и более процессов? Т.е. то же самое, что и при прерывании (сохранение rip, слова состояния программы и всех регистров)?

26 ответов

4 просмотра

если ядро одно и на нём запущено несколько потоков, то да, по прерыванию таймера(допустим раз в 10мс) вызывается планировщик, который меняет данные

Самый маленький- Автор вопроса
Mixail Frolov
если ядро одно и на нём запущено несколько потоков...

А avx тоже сохраняются? Это ж крайне долго, однако при текстах с перемножением матриц я получил падение производительности при > 4 потоках ~ в 1,5 раза, но с увеличением числа потоков серьёзной разницы я не заметил. В чём магия?

Самый маленький
А avx тоже сохраняются? Это ж крайне долго, однако...

авх сохраняются только если они использованы

Самый маленький
А avx тоже сохраняются? Это ж крайне долго, однако...

долго потому что перед использованием avx сохраняется состояние sse. поэтому надо крайне внимательно за этим смотреть и делать код так чтоб в больших циклах отсутстовали вызовы sse или апи ос (она тоже использует sse и контекст приходится переключать) и не смешивать sse+avx

Самый маленький- Автор вопроса
Mixail Frolov
авх сохраняются только если они использованы

Их дефолтными значениями забивают? Скорее всего нет, тогда как это определяется?

Самый маленький- Автор вопроса
Aiwan \ (•◡•) / _bot
долго потому что перед использованием avx сохраняе...

Ты именно про многопоток? Я просто не уловил взаимосвязь между большими циклами и sse.

Самый маленький
Ты именно про многопоток? Я просто не уловил взаим...

нельзя смешивать в коде работу sse и avx. как вариант у тебя это произошло

Самый маленький- Автор вопроса
Aiwan \ (•◡•) / _bot
нельзя смешивать в коде работу sse и avx. как вари...

Не, я наивный вариант написал и без оптимизаций.

Самый маленький- Автор вопроса
Aiwan \ (•◡•) / _bot
долго потому что перед использованием avx сохраняе...

Так ладно, а как всё-таки взаимосвязаны тогда sse и avx? avx же отдельный блок

Самый маленький
Их дефолтными значениями забивают? Скорее всего не...

а может и нет проверки и всё сохраняется при каждом переключении :)

Самый маленький- Автор вопроса
Самый маленький
А avx тоже сохраняются? Это ж крайне долго, однако...

С avx как и с sse есть какие-то способы не сохранять, если не используется

Aiwan \ (•◡•) / _bot
долго потому что перед использованием avx сохраняе...

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

Самый маленький- Автор вопроса
disba1ancer
С avx как и с sse есть какие-то способы не сохраня...

В том то и вопрос, какие способы и как определяется их использование? Плюс хотелось бы узнать подробнее про смешивание sse и avx, а также про циклы с ними (ну то, что писал Айван), а также почему с увеличение количества потоков (с определенного значения > количества ядер) не ухудшается производительность?

Самый маленький
В том то и вопрос, какие способы и как определяетс...

Ну как я понял смешивание инструкций только вызывает проблемы производительности, к сохранению состояния это не относится, а про какие потоки вопрос?

Самый маленький- Автор вопроса
disba1ancer
Ну как я понял смешивание инструкций только вызыва...

Так изначально вопрос то и был про производительность)) Про обычные треды вин32.

Самый маленький
Так изначально вопрос то и был про производительно...

Ну вообще, когда потоков больше чем ядер производительность отдельно взятого потока падает, но обычно в системе не так много активных потоков чтобы это было заметно

Самый маленький- Автор вопроса
disba1ancer
Ну вообще, когда потоков больше чем ядер производи...

Ну я ж замерил - взял перемножение матриц, распараллелил, и получил, что производительность на 6 потоках в пределах погрешности совпадает с производительностью на 12, при 4 реальных ядрах.

Самый маленький
Ну я ж замерил - взял перемножение матриц, распара...

Т.е ты перемножал одну матрицу кучей потоков, так?

Самый маленький- Автор вопроса
disba1ancer
Т.е ты перемножал одну матрицу кучей потоков, так?

Ну взял две матрицы и перемножал одну на другую

Самый маленький- Автор вопроса
Самый маленький
Ну взял две матрицы и перемножал одну на другую

Ну так если все потоки по сути работают над общей задачей значительного падения не будет, будет некоторый оверхед на переключение контекста и всё, потому, чтобы выжать максимум, нужно рабочих потоков по числу ядер держать

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

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

А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Где в Астане можно купить мясо для шашлыков?
Dancing Іңұқәһүғө
21
Добрый день подскажите пожалуйста может кто то сталкивался с ошибками Sentry 22.10.0 развернутым из helm чарт в Kubernetes? Изначально 3 дня назад очень стало много событий ух...
Tire4 Finist Devops
1
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
почому оно не работает?
Vi Chapmann Chapmann
19
всем привет почти закончил курс После него можно писать свою операционку? Какие библиотеки надо использовать и куда дальше копать для изучения
Linus
19
Так а кто может спарсить всех участников чата? Идишники
Magic
18
Карта сайта