Linux Kernel (Ядро линукса) (часть 2)


Вспомогательные функции для когерентного DMA-отображения

Обычно драйвер устройства выделяет буфер памяти и задает когерентное DMA-отображение на этапе инициализации. Он освобождает отображение и буфер, когда выгружается. Для выделения буфера и задания когерентного отображения ядро предоставляет архитектурно-зависимые функции pci_aiioc_ consistent о и dma aiioc coherent о. Обе они возвращают линейный адрес и адрес шины нового буфера. В архитектуре 80x86 они возвращают линейный и физический адреса нового буфера. Для освобождения отображения и буфера ядро предоставляет функции pci_free_consistent И dma f ree coherent .

Вспомогательные функции для потокового DMA-отображения

Буферы памяти для потоковых DMA-отображений обычно выделяются непосредственно перед пересылкой данных и освобождаются сразу после ее окончания. Можно использовать одно отображение для нескольких пересылок, но в этом случае разработчик драйвера должен учитывать наличие аппаратного кэша между памятью и периферией.

Для организации потоковой DMA-пересылки драйвер должен вначале выделить буфер памяти с помощью зонного аллокатора страничных кадров или общего аллокатора памяти Затем драйвер должен установить потоковое DMA-отображение, вызвав либо функцию pci map singieo, либо dma_map_single , которые принимают в качестве параметра линейный адрес буфера и возвращают его адрес шины. Чтобы освободить отображение, драйвер вызывает, соответственно, функцию pci_unmap_singie, либо dma_unmap_single .
Во избежание проблем когерентности, непосредственно перед началом пересылки данных из оперативной памяти устройству (с использованием механизма DMA) драйвер должен вызвать функцию pci_dma_sync_single_
for_device() ИЛИ функцию dma_sync_single_for_device , которые В случае необходимости очищают строки кэша, соответствующие буферу прямого доступа к памяти. Аналогичным образом, драйверу устройства не следует читать буфер памяти сразу по окончании пересылки данных от устройства в оперативную память. Перед чтением буфера драйвер должен вызвать функцию pci_dma_sync_single_for_cpu ИЛИ функцию dma_sync_single_for_cpu , которые, если нужно, очищают соответствующие строки аппаратного кэша. В архитектуре 80x86 эти функции практически ничего не делают, поскольку когерентность между аппаратными кэшами и схемами DMA поддерживается на уровне аппаратуры.

Для пересылки данных с использованием прямого доступа к памяти годятся и буферы в верхних областях памяти Разработчик должен вызвать функцию pci map page ИЛИ функцию dma map page , передав В качестве параметра дескриптор адреса страницы, содержащей буфер, и смещение буфера внутри страницы. Соответственно, чтобы освободить отображение буфера верхней памяти, разработчик вызывает функцию pci unmap page или
dma_unmap_page .

Предыдущая страница | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 | Следующая страница




Возможно, Вас также заинтересует:

ОС Knoppix - это Linux без про...

ВведениеЕсли вы цените свое время, умеете считать деньги и знаете стоимость информации, то эта книга...

Linux Kernel (Ядро линукса) (ч...

Спин-блокировкаСпин-блокировка необходима в многопроцессорной системе, потому что могут возникнуть...

Linux Kernel (Ядро линукса) (ч...

Копирование при записи В системах Unix первых поколений создание процесса было реализовано довольно...

Linux Kernel (Ядро линукса) (ч...

Буферы блоков и головы буферовУ каждого буфера есть дескриптор голова буфера, имеющий тип buffer...