vtables.c 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563
  1. /* libio vtable validation.
  2. Copyright (C) 2016-2026 Free Software Foundation, Inc.
  3. This file is part of the GNU C Library.
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Lesser General Public
  6. License as published by the Free Software Foundation; either
  7. version 2.1 of the License, or (at your option) any later version.
  8. The GNU C Library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public
  13. License along with the GNU C Library; if not, see
  14. <https://www.gnu.org/licenses/>. */
  15. #include <dlfcn.h>
  16. #include <libioP.h>
  17. #include <stdio.h>
  18. #include <ldsodefs.h>
  19. #include <array_length.h>
  20. #include <pointer_guard.h>
  21. #include <libio-macros.h>
  22. /* Both _IO_str_* and _IO_new_file functions are pulled into every link (from
  23. stdio initialization). */
  24. #ifndef SHARED
  25. /* NB: the following directives do add pragma weak for _IO_default _* and
  26. _IO_wdefault_* symbols to potentially avoid link failures, since they
  27. are always used when the __io_vtables is used. */
  28. # pragma weak _IO_wstr_finish
  29. # pragma weak _IO_wstr_overflow
  30. # pragma weak _IO_wstr_pbackfail
  31. # pragma weak _IO_wstr_seekoff
  32. # pragma weak _IO_wstr_underflow
  33. # pragma weak _IO_file_close
  34. # pragma weak _IO_file_close_mmap
  35. # pragma weak _IO_file_doallocate
  36. # pragma weak _IO_file_finish
  37. # pragma weak _IO_file_overflow
  38. # pragma weak _IO_file_read
  39. # pragma weak _IO_file_seek
  40. # pragma weak _IO_file_seekoff_maybe_mmap
  41. # pragma weak _IO_file_seekoff_mmap
  42. # pragma weak _IO_file_setbuf
  43. # pragma weak _IO_file_setbuf_mmap
  44. # pragma weak _IO_file_setbuf_mmap
  45. # pragma weak _IO_file_stat
  46. # pragma weak _IO_file_sync
  47. # pragma weak _IO_file_sync_mmap
  48. # pragma weak _IO_file_underflow
  49. # pragma weak _IO_file_underflow_maybe_mmap
  50. # pragma weak _IO_file_underflow_mmap
  51. # pragma weak _IO_file_xsgetn
  52. # pragma weak _IO_file_xsgetn_maybe_mmap
  53. # pragma weak _IO_file_xsgetn_mmap
  54. # pragma weak _IO_file_xsputn
  55. # pragma weak _IO_wfile_overflow
  56. # pragma weak _IO_wfile_sync
  57. # pragma weak _IO_wfile_underflow
  58. # pragma weak _IO_wfile_underflow_maybe_mmap
  59. # pragma weak _IO_wfile_underflow_mmap
  60. # pragma weak _IO_wfile_doallocate
  61. # pragma weak _IO_wfile_seekoff
  62. # pragma weak _IO_wfile_xsputn
  63. # pragma weak _IO_new_proc_close
  64. # pragma weak _IO_cookie_close
  65. # pragma weak _IO_cookie_read
  66. # pragma weak _IO_cookie_seek
  67. # pragma weak _IO_cookie_seekoff
  68. # pragma weak _IO_cookie_write
  69. # pragma weak _IO_mem_finish
  70. # pragma weak _IO_mem_sync
  71. # pragma weak _IO_wmem_finish
  72. # pragma weak _IO_wmem_sync
  73. # pragma weak __printf_buffer_as_file_overflow
  74. # pragma weak __printf_buffer_as_file_xsputn
  75. # pragma weak __wprintf_buffer_as_file_overflow
  76. # pragma weak __wprintf_buffer_as_file_xsputn
  77. #endif
  78. const struct _IO_jump_t __io_vtables[] attribute_relro =
  79. {
  80. /* _IO_str_jumps */
  81. [IO_STR_JUMPS] =
  82. {
  83. JUMP_INIT_DUMMY,
  84. JUMP_INIT (finish, _IO_str_finish),
  85. JUMP_INIT (overflow, _IO_str_overflow),
  86. JUMP_INIT (underflow, _IO_str_underflow),
  87. JUMP_INIT (uflow, _IO_default_uflow),
  88. JUMP_INIT (pbackfail, _IO_str_pbackfail),
  89. JUMP_INIT (xsputn, _IO_default_xsputn),
  90. JUMP_INIT (xsgetn, _IO_default_xsgetn),
  91. JUMP_INIT (seekoff, _IO_str_seekoff),
  92. JUMP_INIT (seekpos, _IO_default_seekpos),
  93. JUMP_INIT (setbuf, _IO_default_setbuf),
  94. JUMP_INIT (sync, _IO_default_sync),
  95. JUMP_INIT (doallocate, _IO_default_doallocate),
  96. JUMP_INIT (read, _IO_default_read),
  97. JUMP_INIT (write, _IO_default_write),
  98. JUMP_INIT (seek, _IO_default_seek),
  99. JUMP_INIT (close, _IO_default_close),
  100. JUMP_INIT (stat, _IO_default_stat),
  101. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  102. JUMP_INIT (imbue, _IO_default_imbue)
  103. },
  104. /* _IO_wstr_jumps */
  105. [IO_WSTR_JUMPS] = {
  106. JUMP_INIT_DUMMY,
  107. JUMP_INIT (finish, _IO_wstr_finish),
  108. JUMP_INIT (overflow, (_IO_overflow_t) _IO_wstr_overflow),
  109. JUMP_INIT (underflow, (_IO_underflow_t) _IO_wstr_underflow),
  110. JUMP_INIT (uflow, (_IO_underflow_t) _IO_wdefault_uflow),
  111. JUMP_INIT (pbackfail, (_IO_pbackfail_t) _IO_wstr_pbackfail),
  112. JUMP_INIT (xsputn, _IO_wdefault_xsputn),
  113. JUMP_INIT (xsgetn, _IO_wdefault_xsgetn),
  114. JUMP_INIT (seekoff, _IO_wstr_seekoff),
  115. JUMP_INIT (seekpos, _IO_default_seekpos),
  116. JUMP_INIT (setbuf, _IO_default_setbuf),
  117. JUMP_INIT (sync, _IO_default_sync),
  118. JUMP_INIT (doallocate, _IO_wdefault_doallocate),
  119. JUMP_INIT (read, _IO_default_read),
  120. JUMP_INIT (write, _IO_default_write),
  121. JUMP_INIT (seek, _IO_default_seek),
  122. JUMP_INIT (close, _IO_default_close),
  123. JUMP_INIT (stat, _IO_default_stat),
  124. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  125. JUMP_INIT (imbue, _IO_default_imbue)
  126. },
  127. /* _IO_file_jumps */
  128. [IO_FILE_JUMPS] = {
  129. JUMP_INIT_DUMMY,
  130. JUMP_INIT (finish, _IO_file_finish),
  131. JUMP_INIT (overflow, _IO_file_overflow),
  132. JUMP_INIT (underflow, _IO_file_underflow),
  133. JUMP_INIT (uflow, _IO_default_uflow),
  134. JUMP_INIT (pbackfail, _IO_default_pbackfail),
  135. JUMP_INIT (xsputn, _IO_file_xsputn),
  136. JUMP_INIT (xsgetn, _IO_file_xsgetn),
  137. JUMP_INIT (seekoff, _IO_new_file_seekoff),
  138. JUMP_INIT (seekpos, _IO_default_seekpos),
  139. JUMP_INIT (setbuf, _IO_new_file_setbuf),
  140. JUMP_INIT (sync, _IO_new_file_sync),
  141. JUMP_INIT (doallocate, _IO_file_doallocate),
  142. JUMP_INIT (read, _IO_file_read),
  143. JUMP_INIT (write, _IO_new_file_write),
  144. JUMP_INIT (seek, _IO_file_seek),
  145. JUMP_INIT (close, _IO_file_close),
  146. JUMP_INIT (stat, _IO_file_stat),
  147. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  148. JUMP_INIT (imbue, _IO_default_imbue)
  149. },
  150. /* _IO_file_jumps_mmap */
  151. [IO_FILE_JUMPS_MMAP] = {
  152. JUMP_INIT_DUMMY,
  153. JUMP_INIT (finish, _IO_file_finish),
  154. JUMP_INIT (overflow, _IO_file_overflow),
  155. JUMP_INIT (underflow, _IO_file_underflow_mmap),
  156. JUMP_INIT (uflow, _IO_default_uflow),
  157. JUMP_INIT (pbackfail, _IO_default_pbackfail),
  158. JUMP_INIT (xsputn, _IO_new_file_xsputn),
  159. JUMP_INIT (xsgetn, _IO_file_xsgetn_mmap),
  160. JUMP_INIT (seekoff, _IO_file_seekoff_mmap),
  161. JUMP_INIT (seekpos, _IO_default_seekpos),
  162. JUMP_INIT (setbuf, (_IO_setbuf_t) _IO_file_setbuf_mmap),
  163. JUMP_INIT (sync, _IO_file_sync_mmap),
  164. JUMP_INIT (doallocate, _IO_file_doallocate),
  165. JUMP_INIT (read, _IO_file_read),
  166. JUMP_INIT (write, _IO_new_file_write),
  167. JUMP_INIT (seek, _IO_file_seek),
  168. JUMP_INIT (close, _IO_file_close_mmap),
  169. JUMP_INIT (stat, _IO_file_stat),
  170. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  171. JUMP_INIT (imbue, _IO_default_imbue)
  172. },
  173. /* _IO_file_jumps_maybe_mmap */
  174. [IO_FILE_JUMPS_MAYBE_MMAP] = {
  175. JUMP_INIT_DUMMY,
  176. JUMP_INIT (finish, _IO_file_finish),
  177. JUMP_INIT (overflow, _IO_file_overflow),
  178. JUMP_INIT (underflow, _IO_file_underflow_maybe_mmap),
  179. JUMP_INIT (uflow, _IO_default_uflow),
  180. JUMP_INIT (pbackfail, _IO_default_pbackfail),
  181. JUMP_INIT (xsputn, _IO_new_file_xsputn),
  182. JUMP_INIT (xsgetn, _IO_file_xsgetn_maybe_mmap),
  183. JUMP_INIT (seekoff, _IO_file_seekoff_maybe_mmap),
  184. JUMP_INIT (seekpos, _IO_default_seekpos),
  185. JUMP_INIT (setbuf, (_IO_setbuf_t) _IO_file_setbuf_mmap),
  186. JUMP_INIT (sync, _IO_new_file_sync),
  187. JUMP_INIT (doallocate, _IO_file_doallocate),
  188. JUMP_INIT (read, _IO_file_read),
  189. JUMP_INIT (write, _IO_new_file_write),
  190. JUMP_INIT (seek, _IO_file_seek),
  191. JUMP_INIT (close, _IO_file_close),
  192. JUMP_INIT (stat, _IO_file_stat),
  193. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  194. JUMP_INIT (imbue, _IO_default_imbue)
  195. },
  196. /* _IO_wfile_jumps */
  197. [IO_WFILE_JUMPS] = {
  198. JUMP_INIT_DUMMY,
  199. JUMP_INIT (finish, _IO_new_file_finish),
  200. JUMP_INIT (overflow, (_IO_overflow_t) _IO_wfile_overflow),
  201. JUMP_INIT (underflow, (_IO_underflow_t) _IO_wfile_underflow),
  202. JUMP_INIT (uflow, (_IO_underflow_t) _IO_wdefault_uflow),
  203. JUMP_INIT (pbackfail, (_IO_pbackfail_t) _IO_wdefault_pbackfail),
  204. JUMP_INIT (xsputn, _IO_wfile_xsputn),
  205. JUMP_INIT (xsgetn, _IO_file_xsgetn),
  206. JUMP_INIT (seekoff, _IO_wfile_seekoff),
  207. JUMP_INIT (seekpos, _IO_default_seekpos),
  208. JUMP_INIT (setbuf, _IO_new_file_setbuf),
  209. JUMP_INIT (sync, (_IO_sync_t) _IO_wfile_sync),
  210. JUMP_INIT (doallocate, _IO_wfile_doallocate),
  211. JUMP_INIT (read, _IO_file_read),
  212. JUMP_INIT (write, _IO_new_file_write),
  213. JUMP_INIT (seek, _IO_file_seek),
  214. JUMP_INIT (close, _IO_file_close),
  215. JUMP_INIT (stat, _IO_file_stat),
  216. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  217. JUMP_INIT (imbue, _IO_default_imbue)
  218. },
  219. /* _IO_wfile_jumps_mmap */
  220. [IO_WFILE_JUMPS_MMAP] = {
  221. JUMP_INIT_DUMMY,
  222. JUMP_INIT (finish, _IO_new_file_finish),
  223. JUMP_INIT (overflow, (_IO_overflow_t) _IO_wfile_overflow),
  224. JUMP_INIT (underflow, (_IO_underflow_t) _IO_wfile_underflow_mmap),
  225. JUMP_INIT (uflow, (_IO_underflow_t) _IO_wdefault_uflow),
  226. JUMP_INIT (pbackfail, (_IO_pbackfail_t) _IO_wdefault_pbackfail),
  227. JUMP_INIT (xsputn, _IO_wfile_xsputn),
  228. JUMP_INIT (xsgetn, _IO_file_xsgetn),
  229. JUMP_INIT (seekoff, _IO_wfile_seekoff),
  230. JUMP_INIT (seekpos, _IO_default_seekpos),
  231. JUMP_INIT (setbuf, _IO_file_setbuf_mmap),
  232. JUMP_INIT (sync, (_IO_sync_t) _IO_wfile_sync),
  233. JUMP_INIT (doallocate, _IO_wfile_doallocate),
  234. JUMP_INIT (read, _IO_file_read),
  235. JUMP_INIT (write, _IO_new_file_write),
  236. JUMP_INIT (seek, _IO_file_seek),
  237. JUMP_INIT (close, _IO_file_close_mmap),
  238. JUMP_INIT (stat, _IO_file_stat),
  239. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  240. JUMP_INIT (imbue, _IO_default_imbue)
  241. },
  242. /* _IO_wfile_jumps_maybe_mmap */
  243. [IO_WFILE_JUMPS_MAYBE_MMAP] = {
  244. JUMP_INIT_DUMMY,
  245. JUMP_INIT (finish, _IO_new_file_finish),
  246. JUMP_INIT (overflow, (_IO_overflow_t) _IO_wfile_overflow),
  247. JUMP_INIT (underflow, (_IO_underflow_t) _IO_wfile_underflow_maybe_mmap),
  248. JUMP_INIT (uflow, (_IO_underflow_t) _IO_wdefault_uflow),
  249. JUMP_INIT (pbackfail, (_IO_pbackfail_t) _IO_wdefault_pbackfail),
  250. JUMP_INIT (xsputn, _IO_wfile_xsputn),
  251. JUMP_INIT (xsgetn, _IO_file_xsgetn),
  252. JUMP_INIT (seekoff, _IO_wfile_seekoff),
  253. JUMP_INIT (seekpos, _IO_default_seekpos),
  254. JUMP_INIT (setbuf, _IO_file_setbuf_mmap),
  255. JUMP_INIT (sync, (_IO_sync_t) _IO_wfile_sync),
  256. JUMP_INIT (doallocate, _IO_wfile_doallocate),
  257. JUMP_INIT (read, _IO_file_read),
  258. JUMP_INIT (write, _IO_new_file_write),
  259. JUMP_INIT (seek, _IO_file_seek),
  260. JUMP_INIT (close, _IO_file_close),
  261. JUMP_INIT (stat, _IO_file_stat),
  262. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  263. JUMP_INIT (imbue, _IO_default_imbue)
  264. },
  265. /* _IO_cookie_jumps */
  266. [IO_COOKIE_JUMPS] = {
  267. JUMP_INIT_DUMMY,
  268. JUMP_INIT (finish, _IO_file_finish),
  269. JUMP_INIT (overflow, _IO_file_overflow),
  270. JUMP_INIT (underflow, _IO_file_underflow),
  271. JUMP_INIT (uflow, _IO_default_uflow),
  272. JUMP_INIT (pbackfail, _IO_default_pbackfail),
  273. JUMP_INIT (xsputn, _IO_file_xsputn),
  274. JUMP_INIT (xsgetn, _IO_default_xsgetn),
  275. JUMP_INIT (seekoff, _IO_cookie_seekoff),
  276. JUMP_INIT (seekpos, _IO_default_seekpos),
  277. JUMP_INIT (setbuf, _IO_file_setbuf),
  278. JUMP_INIT (sync, _IO_file_sync),
  279. JUMP_INIT (doallocate, _IO_file_doallocate),
  280. JUMP_INIT (read, _IO_cookie_read),
  281. JUMP_INIT (write, _IO_cookie_write),
  282. JUMP_INIT (seek, _IO_cookie_seek),
  283. JUMP_INIT (close, _IO_cookie_close),
  284. JUMP_INIT (stat, _IO_default_stat),
  285. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  286. JUMP_INIT (imbue, _IO_default_imbue),
  287. },
  288. /* _IO_proc_jumps */
  289. [IO_PROC_JUMPS] = {
  290. JUMP_INIT_DUMMY,
  291. JUMP_INIT (finish, _IO_new_file_finish),
  292. JUMP_INIT (overflow, _IO_new_file_overflow),
  293. JUMP_INIT (underflow, _IO_new_file_underflow),
  294. JUMP_INIT (uflow, _IO_default_uflow),
  295. JUMP_INIT (pbackfail, _IO_default_pbackfail),
  296. JUMP_INIT (xsputn, _IO_new_file_xsputn),
  297. JUMP_INIT (xsgetn, _IO_default_xsgetn),
  298. JUMP_INIT (seekoff, _IO_new_file_seekoff),
  299. JUMP_INIT (seekpos, _IO_default_seekpos),
  300. JUMP_INIT (setbuf, _IO_new_file_setbuf),
  301. JUMP_INIT (sync, _IO_new_file_sync),
  302. JUMP_INIT (doallocate, _IO_file_doallocate),
  303. JUMP_INIT (read, _IO_file_read),
  304. JUMP_INIT (write, _IO_new_file_write),
  305. JUMP_INIT (seek, _IO_file_seek),
  306. JUMP_INIT (close, _IO_new_proc_close),
  307. JUMP_INIT (stat, _IO_file_stat),
  308. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  309. JUMP_INIT (imbue, _IO_default_imbue)
  310. },
  311. /* _IO_mem_jumps */
  312. [IO_MEM_JUMPS] = {
  313. JUMP_INIT_DUMMY,
  314. JUMP_INIT (finish, _IO_mem_finish),
  315. JUMP_INIT (overflow, _IO_str_overflow),
  316. JUMP_INIT (underflow, _IO_str_underflow),
  317. JUMP_INIT (uflow, _IO_default_uflow),
  318. JUMP_INIT (pbackfail, _IO_str_pbackfail),
  319. JUMP_INIT (xsputn, _IO_default_xsputn),
  320. JUMP_INIT (xsgetn, _IO_default_xsgetn),
  321. JUMP_INIT (seekoff, _IO_str_seekoff),
  322. JUMP_INIT (seekpos, _IO_default_seekpos),
  323. JUMP_INIT (setbuf, _IO_default_setbuf),
  324. JUMP_INIT (sync, _IO_mem_sync),
  325. JUMP_INIT (doallocate, _IO_default_doallocate),
  326. JUMP_INIT (read, _IO_default_read),
  327. JUMP_INIT (write, _IO_default_write),
  328. JUMP_INIT (seek, _IO_default_seek),
  329. JUMP_INIT (close, _IO_default_close),
  330. JUMP_INIT (stat, _IO_default_stat),
  331. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  332. JUMP_INIT (imbue, _IO_default_imbue)
  333. },
  334. /* _IO_wmem_jumps */
  335. [IO_WMEM_JUMPS] = {
  336. JUMP_INIT_DUMMY,
  337. JUMP_INIT (finish, _IO_wmem_finish),
  338. JUMP_INIT (overflow, (_IO_overflow_t) _IO_wstr_overflow),
  339. JUMP_INIT (underflow, (_IO_underflow_t) _IO_wstr_underflow),
  340. JUMP_INIT (uflow, (_IO_underflow_t) _IO_wdefault_uflow),
  341. JUMP_INIT (pbackfail, (_IO_pbackfail_t) _IO_wstr_pbackfail),
  342. JUMP_INIT (xsputn, _IO_wdefault_xsputn),
  343. JUMP_INIT (xsgetn, _IO_wdefault_xsgetn),
  344. JUMP_INIT (seekoff, _IO_wstr_seekoff),
  345. JUMP_INIT (seekpos, _IO_default_seekpos),
  346. JUMP_INIT (setbuf, _IO_default_setbuf),
  347. JUMP_INIT (sync, _IO_wmem_sync),
  348. JUMP_INIT (doallocate, _IO_wdefault_doallocate),
  349. JUMP_INIT (read, _IO_default_read),
  350. JUMP_INIT (write, _IO_default_write),
  351. JUMP_INIT (seek, _IO_default_seek),
  352. JUMP_INIT (close, _IO_default_close),
  353. JUMP_INIT (stat, _IO_default_stat),
  354. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  355. JUMP_INIT (imbue, _IO_default_imbue)
  356. },
  357. [IO_PRINTF_BUFFER_AS_FILE_JUMPS] = {
  358. JUMP_INIT_DUMMY,
  359. JUMP_INIT (finish, NULL),
  360. JUMP_INIT (overflow, __printf_buffer_as_file_overflow),
  361. JUMP_INIT (underflow, NULL),
  362. JUMP_INIT (uflow, NULL),
  363. JUMP_INIT (pbackfail, NULL),
  364. JUMP_INIT (xsputn, __printf_buffer_as_file_xsputn),
  365. JUMP_INIT (xsgetn, NULL),
  366. JUMP_INIT (seekoff, NULL),
  367. JUMP_INIT (seekpos, NULL),
  368. JUMP_INIT (setbuf, NULL),
  369. JUMP_INIT (sync, NULL),
  370. JUMP_INIT (doallocate, NULL),
  371. JUMP_INIT (read, NULL),
  372. JUMP_INIT (write, NULL),
  373. JUMP_INIT (seek, NULL),
  374. JUMP_INIT (close, NULL),
  375. JUMP_INIT (stat, NULL),
  376. JUMP_INIT (showmanyc, NULL),
  377. JUMP_INIT (imbue, NULL)
  378. },
  379. [IO_WPRINTF_BUFFER_AS_FILE_JUMPS] = {
  380. JUMP_INIT_DUMMY,
  381. JUMP_INIT (finish, NULL),
  382. JUMP_INIT (overflow, (_IO_overflow_t) __wprintf_buffer_as_file_overflow),
  383. JUMP_INIT (underflow, NULL),
  384. JUMP_INIT (uflow, NULL),
  385. JUMP_INIT (pbackfail, NULL),
  386. JUMP_INIT (xsputn, __wprintf_buffer_as_file_xsputn),
  387. JUMP_INIT (xsgetn, NULL),
  388. JUMP_INIT (seekoff, NULL),
  389. JUMP_INIT (seekpos, NULL),
  390. JUMP_INIT (setbuf, NULL),
  391. JUMP_INIT (sync, NULL),
  392. JUMP_INIT (doallocate, NULL),
  393. JUMP_INIT (read, NULL),
  394. JUMP_INIT (write, NULL),
  395. JUMP_INIT (seek, NULL),
  396. JUMP_INIT (close, NULL),
  397. JUMP_INIT (stat, NULL),
  398. JUMP_INIT (showmanyc, NULL),
  399. JUMP_INIT (imbue, NULL)
  400. },
  401. #if SHLIB_COMPAT (libc, GLIBC_2_0, GLIBC_2_1)
  402. /* _IO_old_file_jumps */
  403. [IO_OLD_FILE_JUMPS] = {
  404. JUMP_INIT_DUMMY,
  405. JUMP_INIT (finish, _IO_old_file_finish),
  406. JUMP_INIT (overflow, _IO_old_file_overflow),
  407. JUMP_INIT (underflow, _IO_old_file_underflow),
  408. JUMP_INIT (uflow, _IO_default_uflow),
  409. JUMP_INIT (pbackfail, _IO_default_pbackfail),
  410. JUMP_INIT (xsputn, _IO_old_file_xsputn),
  411. JUMP_INIT (xsgetn, _IO_default_xsgetn),
  412. JUMP_INIT (seekoff, _IO_old_file_seekoff),
  413. JUMP_INIT (seekpos, _IO_default_seekpos),
  414. JUMP_INIT (setbuf, _IO_old_file_setbuf),
  415. JUMP_INIT (sync, _IO_old_file_sync),
  416. JUMP_INIT (doallocate, _IO_file_doallocate),
  417. JUMP_INIT (read, _IO_file_read),
  418. JUMP_INIT (write, _IO_old_file_write),
  419. JUMP_INIT (seek, _IO_file_seek),
  420. JUMP_INIT (close, _IO_file_close),
  421. JUMP_INIT (stat, _IO_file_stat)
  422. },
  423. /* _IO_old_proc_jumps */
  424. [IO_OLD_PROC_JUMPS] = {
  425. JUMP_INIT_DUMMY,
  426. JUMP_INIT (finish, _IO_old_file_finish),
  427. JUMP_INIT (overflow, _IO_old_file_overflow),
  428. JUMP_INIT (underflow, _IO_old_file_underflow),
  429. JUMP_INIT (uflow, _IO_default_uflow),
  430. JUMP_INIT (pbackfail, _IO_default_pbackfail),
  431. JUMP_INIT (xsputn, _IO_old_file_xsputn),
  432. JUMP_INIT (xsgetn, _IO_default_xsgetn),
  433. JUMP_INIT (seekoff, _IO_old_file_seekoff),
  434. JUMP_INIT (seekpos, _IO_default_seekpos),
  435. JUMP_INIT (setbuf, _IO_old_file_setbuf),
  436. JUMP_INIT (sync, _IO_old_file_sync),
  437. JUMP_INIT (doallocate, _IO_file_doallocate),
  438. JUMP_INIT (read, _IO_file_read),
  439. JUMP_INIT (write, _IO_old_file_write),
  440. JUMP_INIT (seek, _IO_file_seek),
  441. JUMP_INIT (close, _IO_old_proc_close),
  442. JUMP_INIT (stat, _IO_file_stat),
  443. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  444. JUMP_INIT (imbue, _IO_default_imbue)
  445. },
  446. #endif
  447. #if SHLIB_COMPAT (libc, GLIBC_2_0, GLIBC_2_2)
  448. /* _IO_old_cookie_jumps */
  449. [IO_OLD_COOKIED_JUMPS] = {
  450. JUMP_INIT_DUMMY,
  451. JUMP_INIT (finish, _IO_file_finish),
  452. JUMP_INIT (overflow, _IO_file_overflow),
  453. JUMP_INIT (underflow, _IO_file_underflow),
  454. JUMP_INIT (uflow, _IO_default_uflow),
  455. JUMP_INIT (pbackfail, _IO_default_pbackfail),
  456. JUMP_INIT (xsputn, _IO_file_xsputn),
  457. JUMP_INIT (xsgetn, _IO_default_xsgetn),
  458. JUMP_INIT (seekoff, _IO_cookie_seekoff),
  459. JUMP_INIT (seekpos, _IO_default_seekpos),
  460. JUMP_INIT (setbuf, _IO_file_setbuf),
  461. JUMP_INIT (sync, _IO_file_sync),
  462. JUMP_INIT (doallocate, _IO_file_doallocate),
  463. JUMP_INIT (read, _IO_cookie_read),
  464. JUMP_INIT (write, _IO_cookie_write),
  465. JUMP_INIT (seek, _IO_old_cookie_seek),
  466. JUMP_INIT (close, _IO_cookie_close),
  467. JUMP_INIT (stat, _IO_default_stat),
  468. JUMP_INIT (showmanyc, _IO_default_showmanyc),
  469. JUMP_INIT (imbue, _IO_default_imbue),
  470. },
  471. #endif
  472. };
  473. _Static_assert (array_length (__io_vtables) == IO_VTABLES_NUM,
  474. "initializer count");
  475. #ifdef SHARED
  476. void (*IO_accept_foreign_vtables) (void) attribute_hidden;
  477. #else /* !SHARED */
  478. /* Used to check whether static dlopen support is needed. */
  479. # pragma weak __dlopen
  480. #endif
  481. void attribute_hidden
  482. _IO_vtable_check (void)
  483. {
  484. #ifdef SHARED
  485. /* Honor the compatibility flag. */
  486. void (*flag) (void) = atomic_load_relaxed (&IO_accept_foreign_vtables);
  487. PTR_DEMANGLE (flag);
  488. if (flag == &_IO_vtable_check)
  489. return;
  490. /* In case this libc copy is in a non-default namespace, we always
  491. need to accept foreign vtables because there is always a
  492. possibility that FILE * objects are passed across the linking
  493. boundary. */
  494. {
  495. Dl_info di;
  496. struct link_map *l;
  497. if (!rtld_active ()
  498. || (_dl_addr (_IO_vtable_check, &di, &l, NULL) != 0
  499. && l->l_ns != LM_ID_BASE))
  500. return;
  501. }
  502. #else /* !SHARED */
  503. /* We cannot perform vtable validation in the static dlopen case
  504. because FILE * handles might be passed back and forth across the
  505. boundary. Therefore, we disable checking in this case. */
  506. if (__dlopen != NULL)
  507. return;
  508. #endif
  509. __libc_fatal ("Fatal error: glibc detected an invalid stdio handle\n");
  510. }
  511. /* Some variants of libstdc++ interpose _IO_2_1_stdin_ etc. and
  512. install their own vtables directly, without calling _IO_init or
  513. other functions. Detect this by looking at the vtables values
  514. during startup, and disable vtable validation in this case. */
  515. #ifdef SHARED
  516. __attribute__ ((constructor))
  517. static void
  518. check_stdfiles_vtables (void)
  519. {
  520. if (_IO_2_1_stdin_.vtable != &_IO_file_jumps
  521. || _IO_2_1_stdout_.vtable != &_IO_file_jumps
  522. || _IO_2_1_stderr_.vtable != &_IO_file_jumps)
  523. IO_set_accept_foreign_vtables (&_IO_vtable_check);
  524. }
  525. #endif
  526. #define STR(s) XSTR(s)
  527. #define XSTR(s) #s
  528. #undef _IO_file_jumps
  529. #define _IO_file_jumps_alias "__io_vtables + " STR(IO_FILE_JUMPS_OFFSET)
  530. declare_object_symbol_alias (_IO_file_jumps, _IO_file_jumps_alias,
  531. IO_JUMP_T_SIZE)
  532. #undef _IO_wfile_jumps
  533. #define _IO_wfile_jumps_alias "__io_vtables + " STR(IO_WFILE_JUMPS_OFFSET)
  534. declare_object_symbol_alias (_IO_wfile_jumps, _IO_wfile_jumps_alias,
  535. IO_JUMP_T_SIZE)