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

У меня такой вопрос про память в x86 возник, может

кто пояснить?..

у процессора есть (как минимум) 3 типа адресов (названия "п1", "п2", "п3" --- мои, чтобы проще было дальше):
- "п1" --- виртуальный адрес, то есть тот, который ресолвится в "п2" по таблице страниц
- "п2" --- адрес, полученный после обхода таблицы страниц, или из TLB
- "п3" --- реальный адрес в плашках, выставляемый на шину

прикол в том, что адреса п2 указывает не в реальную память, а резолвятся через карту памяти (https://en.wikipedia.org/wiki/Memory_map#PC_BIOS_memory_map). То есть этот адрес может указывать на реальный байт в плашках, на регистр конфигурации внешнего устройства, на кусок биоса итд

Когда в драйверах устройству передаётся команда выполнить DMA, то устройству передаётся "физический адрес" --- например, в случае чтения, это адрес, в который требуется записать прочитанные данные

и вот мой вопрос в том, какой из адресов --- п2 или п3 --- называется "физический"

потому что если это п2, то значит ли, что при определённых условиях аудиокарта может мне перепрошить биос?..

10 ответов

30 просмотров
Toideng- Автор вопроса

плохая ссылка, извините вот лучше: https://wiki.osdev.org/Memory_Map_(x86)#Overview

У тебя ужасное описание, п1, п2.. Все ересь. Для простоты у тебя есть физический и виртуальный адрес, все. Физический преобразуется в виртуальный через таблицу страниц.

Toideng- Автор вопроса
Alexey Kaptur
У тебя ужасное описание, п1, п2.. Все ересь. Для п...

я специально их назвал п1, п2, и п3, потому что я не понимаю, какой из них --- п2 или п3 --- называется "физический"

Toideng
я специально их назвал п1, п2, и п3, потому что я ...

Есть ещё логический адрес, но если у тебя нет сегиентации, то он совпадает с виртуальным.

Есть п1 и п3, виртуальный адрес и физический. Но физический адрес может быть ремаплен в адрес другого устройства (не памяти). Дальше все зависит от реализации. Если дма может выставить адрес который контроллером памяти промапится на другой девайс вместо памяти - через дма можно и фигню получить.

Насколько мне известно "п3" адреса на x86 не доступны, потому всё "п2"

Toideng- Автор вопроса
disba1ancer
Насколько мне известно "п3" адреса на x86 не досту...

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

disba1ancer
Насколько мне известно "п3" адреса на x86 не досту...

Разве карта адресов - это не настоящие адреса? Не считая memory-mapped io

Evg Resh
Разве карта адресов - это не настоящие адреса? Не ...

Иногда на платформе может быть 2 MMU, одно непосредственное процессорное, а другое iommu при этом оба могут быть на одном кристалле

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

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

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
приветы , подскажите что я не так сделал , почему у меня скрипт не работает в программе Revit ? ;Autohotkey_RU IfWinActive ("ahk_exe Revit.exe") ; только в открытом Revit Gu...
Anton Terentev
2
> комьюнити я бы не судил по этому чату. Как мы видели по статам просмотров нескольких телеговских постов, то в чате их набивается 30-40 или даже выше, когда как общаются акти...
Constantin F.
4
void bytes2hex(uint8_t* to, uint8_t* from, uint16_t l) { // len(from) == l; len(to) == l * 2 for (uint16_t i = 0; i < l; ++i) { *(to++) = hex[(from[i] >> 4) & ...
#
3
Погодь, а как ты переопределяешь функцию в хедере? Эрланг это же не С, тут явный вызов макросов
Maksim Lapshin
6
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Как сделать чтобы short точно был 2 байта, int точно 4 байта ?(без стандартных библиотек, ну типа без int16_t, int32_t)
#
8
Всем привет. Испытываю проблемы в работе БД, а именно огромного роста логов, такого характера: 024-05-16 18:39:07 +05 sentry sentry [unknown] 1050169 7-1 app-sentry01.corp.ru>...
Alexey
2
Карта сайта