Linux Man на русском

  User    Syst    Libr    Device    Files    Other    Admin  



   s390_pci_mmio_write - обмен данными со страницей памяти

s390_pci_mmio_write(2) обмен данными со страницей памяти

Other Alias

s390_pci_mmio_read


ОБЗОР

#include <asm/unistd.h>
int s390_pci_mmio_write(unsigned long mmio_addr,
void *user_buffer, size_t length);
int s390_pci_mmio_read(unsigned long mmio_addr,
void *user_buffer, size_t length);


ОПИСАНИЕ

Системный вызов s390_pci_mmio_write() записывает length байт данных из буфера user_buffer пользовательского пространства в память PCI MMIO по адресу, указанному в mmio_addr. Системный вызов s390_pci_mmio_read() читает length байт данных начиная с адреса mmio_addr в памяти PCI MMIO и записывает их в буфер пользовательского пространства user_buffer.

Данные системные вызовы должны использоваться вместо простых операций назначения данных, используемых для доступа к областям памяти PCI MMIO, отображенным в пользовательское пространство на платформе Linux System z. Адрес, указываемый в mmio_addr, должен принадлежать отображению страницы памяти PCI MMIO в адресном пространстве вызывающего, а записываемые или читаемые данные не должны пересекать границу страницы. Значение length не может быть больше размера системной страницы.


ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении s390_pci_mmio_write() и s390_pci_mmio_read() возвращают 0. При ошибке возвращается -1, а в errno содержится один из кодов ошибки, перечисленных далее.


ОШИБКИ

EFAULT Некорректный адрес в mmio_addr.

EFAULT Адрес user_buffer не ссылается на корректную точку в адресном пространстве вызывающего.

EINVAL Некорректное значение аргумента length.

ENODEV Поддержка PCI выключена.

ENOMEM Недостаточно памяти.

ВЕРСИИ

Данные системные вызовы появились в Linux 3.19.


СООТВЕТСТВИЕ СТАНДАРТАМ

Данный системный вызов есть только в Linux и доступен только на архитектуре s390. Требуемая поддержка PCI доступна начиная с System z EC12.


ЗАМЕЧАНИЯ

В glibc нет обёртки для данного системного вызова; запускайте его с помощью syscall(2).