OSSL_ALGORITHM.3ossl 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. .\" Automatically generated by Pod::Man 4.14 (Pod::Simple 3.42)
  2. .\"
  3. .\" Standard preamble:
  4. .\" ========================================================================
  5. .de Sp \" Vertical space (when we can't use .PP)
  6. .if t .sp .5v
  7. .if n .sp
  8. ..
  9. .de Vb \" Begin verbatim text
  10. .ft CW
  11. .nf
  12. .ne \\$1
  13. ..
  14. .de Ve \" End verbatim text
  15. .ft R
  16. .fi
  17. ..
  18. .\" Set up some character translations and predefined strings. \*(-- will
  19. .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left
  20. .\" double quote, and \*(R" will give a right double quote. \*(C+ will
  21. .\" give a nicer C++. Capital omega is used to do unbreakable dashes and
  22. .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff,
  23. .\" nothing in troff, for use with C<>.
  24. .tr \(*W-
  25. .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p'
  26. .ie n \{\
  27. . ds -- \(*W-
  28. . ds PI pi
  29. . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch
  30. . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch
  31. . ds L" ""
  32. . ds R" ""
  33. . ds C` ""
  34. . ds C' ""
  35. 'br\}
  36. .el\{\
  37. . ds -- \|\(em\|
  38. . ds PI \(*p
  39. . ds L" ``
  40. . ds R" ''
  41. . ds C`
  42. . ds C'
  43. 'br\}
  44. .\"
  45. .\" Escape single quotes in literal strings from groff's Unicode transform.
  46. .ie \n(.g .ds Aq \(aq
  47. .el .ds Aq '
  48. .\"
  49. .\" If the F register is >0, we'll generate index entries on stderr for
  50. .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index
  51. .\" entries marked with X<> in POD. Of course, you'll have to process the
  52. .\" output yourself in some meaningful fashion.
  53. .\"
  54. .\" Avoid warning from groff about undefined register 'F'.
  55. .de IX
  56. ..
  57. .nr rF 0
  58. .if \n(.g .if rF .nr rF 1
  59. .if (\n(rF:(\n(.g==0)) \{\
  60. . if \nF \{\
  61. . de IX
  62. . tm Index:\\$1\t\\n%\t"\\$2"
  63. ..
  64. . if !\nF==2 \{\
  65. . nr % 0
  66. . nr F 2
  67. . \}
  68. . \}
  69. .\}
  70. .rr rF
  71. .\"
  72. .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2).
  73. .\" Fear. Run. Save yourself. No user-serviceable parts.
  74. . \" fudge factors for nroff and troff
  75. .if n \{\
  76. . ds #H 0
  77. . ds #V .8m
  78. . ds #F .3m
  79. . ds #[ \f1
  80. . ds #] \fP
  81. .\}
  82. .if t \{\
  83. . ds #H ((1u-(\\\\n(.fu%2u))*.13m)
  84. . ds #V .6m
  85. . ds #F 0
  86. . ds #[ \&
  87. . ds #] \&
  88. .\}
  89. . \" simple accents for nroff and troff
  90. .if n \{\
  91. . ds ' \&
  92. . ds ` \&
  93. . ds ^ \&
  94. . ds , \&
  95. . ds ~ ~
  96. . ds /
  97. .\}
  98. .if t \{\
  99. . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u"
  100. . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u'
  101. . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u'
  102. . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u'
  103. . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u'
  104. . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u'
  105. .\}
  106. . \" troff and (daisy-wheel) nroff accents
  107. .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V'
  108. .ds 8 \h'\*(#H'\(*b\h'-\*(#H'
  109. .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#]
  110. .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H'
  111. .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u'
  112. .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#]
  113. .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#]
  114. .ds ae a\h'-(\w'a'u*4/10)'e
  115. .ds Ae A\h'-(\w'A'u*4/10)'E
  116. . \" corrections for vroff
  117. .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u'
  118. .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u'
  119. . \" for low resolution devices (crt and lpr)
  120. .if \n(.H>23 .if \n(.V>19 \
  121. \{\
  122. . ds : e
  123. . ds 8 ss
  124. . ds o a
  125. . ds d- d\h'-1'\(ga
  126. . ds D- D\h'-1'\(hy
  127. . ds th \o'bp'
  128. . ds Th \o'LP'
  129. . ds ae ae
  130. . ds Ae AE
  131. .\}
  132. .rm #[ #] #H #V #F C
  133. .\" ========================================================================
  134. .\"
  135. .IX Title "OSSL_ALGORITHM 3ossl"
  136. .TH OSSL_ALGORITHM 3ossl "2024-09-03" "3.3.2" "OpenSSL"
  137. .\" For nroff, turn off justification. Always turn off hyphenation; it makes
  138. .\" way too many mistakes in technical documents.
  139. .if n .ad l
  140. .nh
  141. .SH "NAME"
  142. OSSL_ALGORITHM \- OpenSSL Core type to define a fetchable algorithm
  143. .SH "SYNOPSIS"
  144. .IX Header "SYNOPSIS"
  145. .Vb 1
  146. \& #include <openssl/core.h>
  147. \&
  148. \& typedef struct ossl_algorithm_st OSSL_ALGORITHM;
  149. \& struct ossl_algorithm_st {
  150. \& const char *algorithm_names; /* key */
  151. \& const char *property_definition; /* key */
  152. \& const OSSL_DISPATCH *implementation;
  153. \& const char *algorithm_description;
  154. \& };
  155. .Ve
  156. .SH "DESCRIPTION"
  157. .IX Header "DESCRIPTION"
  158. The \fB\s-1OSSL_ALGORITHM\s0\fR type is a \fIpublic structure\fR that describes an
  159. algorithm that a \fBprovider\fR\|(7) provides. Arrays of this type are returned
  160. by providers on demand from the OpenSSL libraries to describe what
  161. algorithms the providers provide implementations of, and with what
  162. properties.
  163. .PP
  164. Arrays of this type must be terminated with a tuple where \fIalgorithm_names\fR
  165. is \s-1NULL.\s0
  166. .PP
  167. This type of array is typically returned by the provider's operation querying
  168. function, further described in \*(L"Provider Functions\*(R" in \fBprovider\-base\fR\|(7).
  169. .SS "\fB\s-1OSSL_ALGORITHM\s0\fP fields"
  170. .IX Subsection "OSSL_ALGORITHM fields"
  171. .IP "\fIalgorithm_names\fR" 4
  172. .IX Item "algorithm_names"
  173. This string is a colon separated set of names / identities, and is used by
  174. the appropriate fetching functionality (such as \fBEVP_CIPHER_fetch\fR\|(3),
  175. \&\fBEVP_MD_fetch\fR\|(3), etc) to find the desired algorithm.
  176. .Sp
  177. Multiple names / identities allow a specific algorithm implementation to be
  178. fetched multiple ways. For example, the \s-1RSA\s0 algorithm has the following
  179. known identities:
  180. .RS 4
  181. .IP "\(bu" 4
  182. \&\f(CW\*(C`RSA\*(C'\fR
  183. .IP "\(bu" 4
  184. \&\f(CW\*(C`rsaEncryption\*(C'\fR
  185. .Sp
  186. This is the name of the algorithm's \s-1OBJECT IDENTIFIER\s0 (\s-1OID\s0), as given by the
  187. PKCS#1 \s-1RFC\s0's \s-1ASN.1\s0 module <https://www.rfc-editor.org/rfc/rfc8017#appendix-C>
  188. .IP "\(bu" 4
  189. \&\f(CW1.2.840.113549.1.1.1\fR
  190. .Sp
  191. This is the \s-1OID\s0 itself for \f(CW\*(C`rsaEncryption\*(C'\fR, in canonical decimal text form.
  192. .RE
  193. .RS 4
  194. .Sp
  195. The resulting \fIalgorithm_names\fR string would look like this:
  196. .Sp
  197. .Vb 1
  198. \& "RSA:rsaEncryption:1.2.840.113549.1.1.1"
  199. .Ve
  200. .Sp
  201. The OpenSSL libraries use the first of the algorithm names as the main
  202. or canonical name, on a per algorithm implementation basis.
  203. .Sp
  204. See the notes \*(L"On the subject of algorithm names\*(R" below for a more in
  205. depth discussion on \fIalgorithm_names\fR and how that may interact with
  206. applications and libraries, including OpenSSL's.
  207. .RE
  208. .IP "\fIproperty_definition\fR" 4
  209. .IX Item "property_definition"
  210. This string defines a set of properties associated with a particular
  211. algorithm implementation, and is used by the appropriate fetching
  212. functionality (such as \fBEVP_CIPHER_fetch\fR\|(3), \fBEVP_MD_fetch\fR\|(3), etc) for
  213. a finer grained lookup of an algorithm implementation, which is useful in
  214. case multiple implementations of the same algorithm are available.
  215. .Sp
  216. See \fBproperty\fR\|(7) for a further description of the contents of this
  217. string.
  218. .IP "\fIimplementation\fR" 4
  219. .IX Item "implementation"
  220. Pointer to an \s-1\fBOSSL_DISPATCH\s0\fR\|(3) array, containing pointers to the
  221. functions of a particular algorithm implementation.
  222. .IP "\fIalgorithm_description\fR" 4
  223. .IX Item "algorithm_description"
  224. A string with a short human-readable description of the algorithm.
  225. .SH "NOTES"
  226. .IX Header "NOTES"
  227. .SS "On the subject of algorithm names"
  228. .IX Subsection "On the subject of algorithm names"
  229. Providers may find the need to register \s-1ASN.1\s0 OIDs for algorithms using
  230. \&\fBOBJ_create\fR\|(3) (via the \fBcore_obj_create\fR upcall described in
  231. \&\fBprovider\-base\fR\|(7), because some application or library \*(-- possibly still
  232. the OpenSSL libraries, even \*(-- use NIDs to look up algorithms.
  233. .PP
  234. In that scenario, you must make sure that the corresponding \fB\s-1OSSL_ALGORITHM\s0\fR's
  235. \&\fIalgorithm_names\fR includes both the short and the long name.
  236. .PP
  237. Most of the time, registering \s-1ASN.1\s0 OIDs like this shouldn't be necessary,
  238. and applications and libraries are encouraged to use \fBOBJ_obj2txt\fR\|(3) to
  239. get a text representation of the \s-1OID,\s0 which may be a long or short name for
  240. OIDs that are registered, or the \s-1OID\s0 itself in canonical decimal text form
  241. if not (or if \fBOBJ_obj2txt\fR\|(3) is called with \fIno_name\fR = 1).
  242. .PP
  243. It's recommended to make sure that the corresponding \fB\s-1OSSL_ALGORITHM\s0\fR's
  244. \&\fIalgorithm_names\fR include known names as well as the \s-1OID\s0 itself in
  245. canonical decimal text form. That should cover all scenarios.
  246. .SH "SEE ALSO"
  247. .IX Header "SEE ALSO"
  248. \&\fBcrypto\fR\|(7), \fBprovider\-base\fR\|(7), \fBopenssl\-core.h\fR\|(7),
  249. \&\fBopenssl\-core_dispatch.h\fR\|(7), \s-1\fBOSSL_DISPATCH\s0\fR\|(3)
  250. .SH "HISTORY"
  251. .IX Header "HISTORY"
  252. \&\fB\s-1OSSL_ALGORITHM\s0\fR was added in OpenSSL 3.0
  253. .SH "COPYRIGHT"
  254. .IX Header "COPYRIGHT"
  255. Copyright 2022 The OpenSSL Project Authors. All Rights Reserved.
  256. .PP
  257. Licensed under the Apache License 2.0 (the \*(L"License\*(R"). You may not use
  258. this file except in compliance with the License. You can obtain a copy
  259. in the file \s-1LICENSE\s0 in the source distribution or at
  260. <https://www.openssl.org/source/license.html>.