Provided by: manpages-ru-dev_4.19.0-7_all bug

ИМЯ

       spu_run - выполняет контекст SPU

LIBRARY

       Standard C library (libc, -lc)

СИНТАКСИС

       #include <sys/spu.h>          /* определения констант SPU_* */
       #include <sys/syscall.h>      /* определения констант SYS_* */
       #include <unistd.h>

       int syscall(SYS_spu_run, int fd, uint32_t *npc, uint32_t *event);

       Note: glibc provides no wrapper for spu_run(), necessitating the use of syscall(2).

ОПИСАНИЕ

       Системный  вызов  spu_run()  используется на машинах PowerPC с архитектурой Cell Broadband
       Engine для получения доступа к Synergistic Processor Unit (SPU). Аргумент fd  представляет
       собой   файловый   дескриптор,   возвращаемый   вызовом  spu_create(2)  и  указывающий  на
       определённый контекст SPU. Когда контекст планируется на физическом SPU, он запускается на
       выполнение начиная с инструкции, на которую указывает значение npc.

       Выполнение  кода  SPU  происходит синхронно, то есть spu_run() блокируется на время работы
       SPU. Если требуется параллельное выполнение кода SPU и кода  на  основном  процессоре  или
       других   SPU,  то  сначала  нужно  создать  новую  нить  выполнения  (например  с  помощью
       pthread_create(3)).

       При завершении работы spu_run() текущее значение программного счётчика SPU записывается  в
       npc, что позволяет использовать тот же указатель npc в последующих вызовах spu_run().

       В  аргументе  event  указывается  буфер для расширенного кода состояния. Если контекст SPU
       создан с флагом SPU_CREATE_EVENTS_ENABLED,  то  ядро  Linux  заполняет  этот  буфер  перед
       возвратом из spu_run().

       Код состояния может быть одной (или несколькими) из следующих констант:

       SPE_EVENT_DMA_ALIGNMENT
              Произошла ошибка выравнивания DMA.

       SPE_EVENT_INVALID_DMA
              Попытка выполнить неверную команду MFC DMA.

       SPE_EVENT_SPE_DATA_STORAGE
              Произошла ошибка хранилища DMA.

       SPE_EVENT_SPE_ERROR
              Выполнена недопустимая инструкция.

       Для  аргумента  event  допускается  значение  NULL. В этом случае информация о событиях не
       будет поступать в вызывающий процесс.

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

       On success, spu_run()  returns the value of  the  spu_status  register.   On  failure,  it
       returns -1 and sets errno is set to indicate the error.

       Значение   регистра   spu_status  представляет  собой  битовую  маску  кодов  состояния  и
       необязательный 14-битный код, возвращаемый при выполнении инструкции stop-and-signal  SPU.
       Битовые маски кодов состояний:

       0x02   SPU остановлен инструкцией stop-and-signal.

       0x04   SPU остановлен инструкцией halt.

       0x08   SPU ожидает канала.

       0x10   SPU в пошаговом режиме.

       0x20   SPU пытался выполнить неверную инструкцию.

       0x40   SPU пытался получить доступ к неверному каналу.

       0x3fff0000
              При  наложении этой маски получается код, возвращаемый инструкцией stop-and-signal.
              Полученные биты корректны только, если установлен бит 0x02.

       Если  spu_run()  не  вернул  ошибку,  то  один  или  более  младших  восьми  битов  всегда
       установлены.

ОШИБКИ

       EBADF  Значение fd не является правильным файловым дескриптором.

       EFAULT Задан  неправильный  указатель  в  npc  или значение event не равно NULL и является
              неправильным указателем.

       EINTR  При выполнении spu_run() получен сигнал; см. signal(7). При необходимости, значение
              npc обновляется до нового значения программного счётчика.

       EINVAL Значение   fd   не   является   правильным   файловым   дескриптором,  возвращённым
              spu_create(2).

       ENOMEM Недостаточно памяти для обработки страничного сбоя  в  результате  прямого  доступа
              Memory Flow Controller (MFC).

       ENOSYS Возможность  не  предоставляется  текущей  системой,  так  как  или  аппаратура  не
              предоставляет SPU, или не загружен модуль spufs.

ВЕРСИИ

       The spu_run()  system call was added in Linux 2.6.16.

СТАНДАРТЫ

       Данный вызов существует только в  Linux  и  реализован  только  для  архитектуры  PowerPC.
       Программы, использующие данный вызов, не переносимы.

ЗАМЕЧАНИЯ

       spu_run()   is meant to be used from libraries that implement a more abstract interface to
       SPUs,  not  to  be  used  from  regular  applications.   See   ⟨http://www.bsc.es/projects
       /deepcomputing/linuxoncell/⟩ for the recommended libraries.

ПРИМЕРЫ

       В  следующем  примере  реализована  простая программа, состоящая из одной инструкции SPU и
       системного вызова spu_run().

       #include <err.h>
       #include <fcntl.h>
       #include <stdint.h>
       #include <stdio.h>
       #include <stdlib.h>
       #include <sys/types.h>
       #include <unistd.h>

       int main(void)
       {
           int       context, fd, spu_status;
           uint32_t  instruction, npc;

           context = syscall(SYS_spu_create, "/spu/example-context", 0, 0755);
           if (context == -1)
               err(EXIT_FAILURE, "spu_create");

           /*
            * Write a 'stop 0x1234' instruction to the SPU's
            * local store memory.
            */
           instruction = 0x00001234;

           fd = open("/spu/example-context/mem", O_RDWR);
           if (fd == -1)
               err(EXIT_FAILURE, "open");
           write(fd, &instruction, sizeof(instruction));

           /*
            * присвоить npc адрес начальной инструкции программы
            * SPU. Так как мы записали инструкцию в начало
            * файла mem, точка входа будет равна 0x0
            */
           npc = 0;

           spu_status = syscall(SYS_spu_run, context, &npc, NULL);
           if (spu_status == -1)
               err(EXIT_FAILURE, "open");

           /*
            * We should see a status code of 0x12340002:
            *   0x00000002 (spu was stopped due to stop-and-signal)
            * | 0x12340000 (the stop-and-signal code)
            */
           printf("SPU Status: %#08x\n", spu_status);

           exit(EXIT_SUCCESS);
       }

СМ. ТАКЖЕ

       close(2), spu_create(2), capabilities(7), spufs(7)

ПЕРЕВОД

       Русский   перевод   этой   страницы   руководства    был    сделан    Alexander    Golubev
       <fatzer2@gmail.com>,   Azamat   Hackimov  <azamat.hackimov@gmail.com>,  Hotellook,  Nikita
       <zxcvbnm3230@mail.ru>,       Spiros       Georgaras       <sng@hellug.gr>,       Vladislav
       <ivladislavefimov@gmail.com>,    Yuri    Kozlov   <yuray@komyakino.ru>   и   Иван   Павлов
       <pavia00@gmail.com>

       Этот  перевод  является  бесплатной  документацией;  прочитайте  Стандартную  общественную
       лицензию GNU версии 3 ⟨https://www.gnu.org/licenses/gpl-3.0.html⟩ или более позднюю, чтобы
       узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ.

       Если вы обнаружите ошибки в переводе  этой  страницы  руководства,  пожалуйста,  отправьте
       электронное письмо на ⟨man-pages-ru-talks@lists.sourceforge.net⟩.