tools_compiler-russian.tex 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. \subsection{Компиляция}
  2. \index{OpenCL компилятор}%
  3. \index{oclh_cr@\texttt{oclh\_cr}}%
  4. Изолированная компиляция осуществляется утилитой \verb|oclh_cr|.
  5. \subsubsection{Синопсис}
  6. \begin{CodeParWithCC}{\\\{\}}
  7. oclh_cr [--dev-idxs=\underline{\smash{\textit{#}}},\underline{\smash{\textit{#}}},... | --dev-name=\underline{\smash{\textit{mask}}}]
  8. [--verbatim-output-name] [-o \underline{\smash{\textit{outfile}}}]
  9. [COMPILER_OPTIONS] \underline{\smash{\textit{infile}}}...
  10. \end{CodeParWithCC}
  11. \subsubsection{Описание}
  12. При вызове \verb|oclh_сr| осуществляется компиляция исходного кода из файлов
  13. \verbIU{infile}\verb|...| для всех доступных в системе устройств GPGPU. Если
  14. указан ключ \verb|--dev-idxs=|\verbIU{\#}\verb|,|\verbIU{\#}\verb|,...|, то
  15. будет осуществлена компиляция только для устройств с индексами
  16. \verbIU{\#}\Verb|,|\verbIU{\#}\Verb|,...|
  17. (подробнее~см.~п.\ref{subsubsec:cr_args}). Если указан ключ
  18. \verb|--dev-name=|\verbIU{mask}, то будет осуществлена компиляция только для
  19. устройств, модель которых соответствует маске \verbIU{mask}
  20. (подробнее~см.~п.\ref{subsubsec:cr_args}).
  21. Во время работы \verb|oclh_сr| ведётся подробный диагностический журнал в
  22. файле \verb|oclh_сr.log|, куда сохраняется избыточная информация обо
  23. всех доступных устройствах GPGPU, используемых платформах и созданных для
  24. компиляции контекстах. Фактически вы можете запустить \verb|oclh_сr| с любым
  25. входным файлом, даже с самим собой, как \verb|./oclh_сr oclh_сr|. Файл, конечно,
  26. не будет скомплирован в объект OpenCL, но в журнале \verb|oclh_сr.log|
  27. останется полная информация по устройствам GPGPU, найденным в системе. Формат
  28. журнала человекочитаем, адаптирован к поиску подстрок с использованием команды
  29. \verb|grep| и аналогов. Формат файла-журнала описан в п.\ref{subsec:logformat}.
  30. Так как компиляция может осуществляться для нескольких устройств разных
  31. производителей, журнал компиляции программы ведётся в отдельных файлах
  32. \verbIU{outfile}\verb|-|\verbI{модель\_устройства\_GPGPU}\verb|-trans.log|.
  33. Результат работы компилятора -- нескомпонованный бинарный объект сохраняется в
  34. файле \verbIU{outfile}\verb|-|\verbI{модель\_устройства\_GPGPU}\verb|.clo|. Если
  35. указан ключ \verb|--verbatim-output-name|, то результат будет сохранен в файле
  36. \verbIU{outfile}. Иногда возникает ситуация, когда библиотека OpenCL
  37. производителя устройства выдала в качестве результата несколько бинарных
  38. объектов, в таком случае все бинарные объекты будут сохранены, но к именам
  39. файлов будет добавлен постфикс \verb|.|\verbI{N}, где \verbI{N}~--~десятичное
  40. число обозначающее порядковый номер (начиная с ноля) двоичного блока
  41. сформированного компилятором производителя устройства GPGPU.
  42. Если ключ \verb|-o| не указан, то \verbIU{outfile} в названии файла будет
  43. заменён на подстроку вида \verb|program_0x|\verbI{HHHH}. В случае если модель
  44. устройства GPGPU средствами OpenCL определить не удалось, тогда
  45. \verbI{модель\_устройства\_GPGPU} будет заменена на подстроку вида
  46. \verb|dev_0x|\verbI{HHHH}. В приведённых подстановках \verbI{HHHH} это
  47. шестнадцатеричное представление последних двух байт адресов программы и
  48. устройства GPGPU, соответственно. Так как для одного запуска адреса программы и
  49. устройства GPGPU уникальны, с высокой вероятностью сочетание названия объекта и
  50. двух последних байт адреса также уникально, поэтому могут быть использованы как
  51. подстрока для поиска связанных записей в файле основного журнала
  52. \verb|oclh_сr.log|.
  53. Имя файла основного журнала \verb|oclh_сr.log| и путь сохранения файлов могут
  54. быть изменены при сборке библиотеки OpenCL\_helpers в заголовочном файле\\*
  55. \indent\indent\verb|src/inc/oclh_settings.h|\\*
  56. Данное имя и путь сохранения журналов и результатов компиляции определены в
  57. макросах\\*
  58. \indent\indent\verb|#define _GHM_LOG_PATH "."|\\*
  59. \indent\indent\verb|#define _GHM_OCLH_COMPILER_LOG_FILENAME "oclh_cr.log"|
  60. Компилятору всегда передаётся аргумент \verb|-D_OCLH_OCL_COMPILER_|. Он
  61. прописан в коде библиотеки и введён для возможности использования заголовочных
  62. файлов как в программах для GPGPU, так и для CPU без их изменения. Подробнее см.
  63. п.\ref{subsec:sharedheaders}.
  64. \subsubsection{Аргументы}
  65. \label{subsubsec:cr_args}
  66. {\NmCnvDescript\verb|--dev-idxs=|\verbIU{\#}\Verb|,|\verbIU{\#}\verb|,...|\\*
  67. числа \verbIU{\#}\verb|,|\verbIU{\#}\verb|,...|, указанные без пробелов через
  68. запятую после ключа \verb|--dev-idxs=| это порядковые номера (индексы) устройств
  69. GPGPU в системе, для которых будет осуществлена компиляция. Индексы начинаются с
  70. ноля. Узнать индекс конкретного устройства можно из файла-журнала, в начальной
  71. секции которого в описании устройства самая первая строка имеет вид\par
  72. {\hspace{2\leftskip}\verbI{YYYY}\verb|-|\verbI{MM}\verb|-|\verbI{DD}%
  73. \verb| |\verbI{hh}\verb|:|\verbI{mm}\verb|:|\verbI{ss}%
  74. \verb| ws_0x|\verbI{HHHH}\verb| dev_0x|\verbI{HHHH}%
  75. \verb+ | Device index: +\verbI{N}},\par
  76. \noindent где \verbI{N}~--~индекс данного устройства.\par}
  77. {\NmCnvDescript\verb|--dev-name=|\verbIU{mask}\\* строка \verbIU{mask},
  78. указанная после ключа \verb|--dev-name=| это маска, которая указывает для каких
  79. моделей устройств, присутствующих в системе будет осуществлена компиляция.
  80. Символами подстановки являются:\par
  81. \hspace{2\leftskip}\verb|?| -- замещает один любой символ;\par
  82. \hspace{2\leftskip}\verb|*| -- замещает любое количество любых символов.\par
  83. \noindent При отсутствии символов подстановки \verbIU{mask} рассматривается как
  84. точное наименование модели устройства. Узнать модель конкретного устройства
  85. можно из файла-журнала, в начальной секции которого в описании устройств
  86. присутствует строка вида\par
  87. {\hspace{2\leftskip}\verbI{YYYY}\verb|-|\verbI{MM}\verb|-|\verbI{DD}%
  88. \verb| |\verbI{hh}\verb|:|\verbI{mm}\verb|:|\verbI{ss}%
  89. \verb| ws_0x|\verbI{HHHH}\verb| dev_0x|\verbI{HHHH}%
  90. \verb+ | Device name: +\verbI{модель}}\par
  91. \noindent где \verbI{модель}~--~и есть строка, которая проверяется на
  92. соответствие маске \verbIU{mask}.\par}
  93. {\NmCnvDescript\verb|--verbatim-output-name|\\* данный ключ предписывает
  94. компилятору не добавлять к имени выходного файла модель устройства и расширение,
  95. а использовать его именно так как указано. Однако, в случае если результатом
  96. работы компилятора является не один двоичный блок, то к имени будет добавлен
  97. постфикс \verb|.|\verbI{N}, где \verbI{N}~--~десятичное число обозначающее
  98. порядковый номер (начиная с ноля) двоичного блока сформированного компилятором
  99. производителя устройства GPGPU.\par}
  100. {\NmCnvDescript\verb|-o |\verbIU{outfile}\\* строка \verbIU{outfile}~--~имя
  101. выходного файла. Если не задан ключ \verb|--verbatim-output-name|, то
  102. \verbIU{outfile} используется как префикс имени файла \verbIU{outfile}\verb|-|%
  103. \verbI{модель\_устройства\_GPGPU}\verb|.clo|, содержащего двоичный блок кода
  104. сформированный в результате компиляции. В случае, если ключ
  105. \verb|--verbatim-output-name| указан, то \verbIU{outfile} используется <<как
  106. есть>>, за исключением случаев, когда в результате компиляции сформированы
  107. несколько двоичных блоков~--~в таком случае все двоичные блоки будут сохранены с
  108. именами файлов \verbIU{outfile}\verb|.|\verbI{N}, где \verbI{N}~--~порядковый
  109. номер двоичного блока начиная с ноля. Кроме того строка \verbIU{outfile} будет
  110. использована как префикс в имени файла-журнала компиляции.\par
  111. \begin{ImpNote}
  112. Пробельные символы в начале и в конце строки \verbIU{outfile} будут удалены.
  113. Пробельные символы внутри строки \verbIU{outfile} будут заменены на знак
  114. подчёркивания~<<\verb|_|>>~(underscore).
  115. \end{ImpNote}
  116. }
  117. {\NmCnvDescript\verb|COMPILER_OPTIONS|\\* аргументы компилятора. В неизменённом
  118. виде и с сохранением последовательности передаются компилятору производителя.
  119. Сами аргументы компилятора описаны в спецификациях OpenCL, кроме того,
  120. компилятор производителя может поддерживать дополнительные аргументы не
  121. отражённые в спецификациях OpenCL.\par}
  122. {\NmCnvDescript\verbIU{infile}\verb|...|\\* список разделённый пробелами с именами файлов содержащих исходный код программы OpenCL C или OpenCL C++. Имя файла не может начинаться с символа~<<\verb|-|>>.\par}