char-socket.c 45 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501
  1. /*
  2. * QEMU System Emulator
  3. *
  4. * Copyright (c) 2003-2008 Fabrice Bellard
  5. *
  6. * Permission is hereby granted, free of charge, to any person obtaining a copy
  7. * of this software and associated documentation files (the "Software"), to deal
  8. * in the Software without restriction, including without limitation the rights
  9. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  10. * copies of the Software, and to permit persons to whom the Software is
  11. * furnished to do so, subject to the following conditions:
  12. *
  13. * The above copyright notice and this permission notice shall be included in
  14. * all copies or substantial portions of the Software.
  15. *
  16. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  19. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  20. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  21. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  22. * THE SOFTWARE.
  23. */
  24. #include "qemu/osdep.h"
  25. #include "chardev/char.h"
  26. #include "io/channel-socket.h"
  27. #include "io/channel-tls.h"
  28. #include "io/channel-websock.h"
  29. #include "io/net-listener.h"
  30. #include "qemu/error-report.h"
  31. #include "qemu/module.h"
  32. #include "qemu/option.h"
  33. #include "qapi/error.h"
  34. #include "qapi/clone-visitor.h"
  35. #include "qapi/qapi-visit-sockets.h"
  36. #include "chardev/char-io.h"
  37. /***********************************************************/
  38. /* TCP Net console */
  39. #define TCP_MAX_FDS 16
  40. typedef struct {
  41. char buf[21];
  42. size_t buflen;
  43. } TCPChardevTelnetInit;
  44. typedef enum {
  45. TCP_CHARDEV_STATE_DISCONNECTED,
  46. TCP_CHARDEV_STATE_CONNECTING,
  47. TCP_CHARDEV_STATE_CONNECTED,
  48. } TCPChardevState;
  49. typedef struct {
  50. Chardev parent;
  51. QIOChannel *ioc; /* Client I/O channel */
  52. QIOChannelSocket *sioc; /* Client master channel */
  53. QIONetListener *listener;
  54. GSource *hup_source;
  55. QCryptoTLSCreds *tls_creds;
  56. char *tls_authz;
  57. TCPChardevState state;
  58. int max_size;
  59. int do_telnetopt;
  60. int do_nodelay;
  61. int *read_msgfds;
  62. size_t read_msgfds_num;
  63. int *write_msgfds;
  64. size_t write_msgfds_num;
  65. SocketAddress *addr;
  66. bool is_listen;
  67. bool is_telnet;
  68. bool is_tn3270;
  69. GSource *telnet_source;
  70. TCPChardevTelnetInit *telnet_init;
  71. bool is_websock;
  72. GSource *reconnect_timer;
  73. int64_t reconnect_time;
  74. bool connect_err_reported;
  75. QIOTask *connect_task;
  76. } SocketChardev;
  77. #define SOCKET_CHARDEV(obj) \
  78. OBJECT_CHECK(SocketChardev, (obj), TYPE_CHARDEV_SOCKET)
  79. static gboolean socket_reconnect_timeout(gpointer opaque);
  80. static void tcp_chr_telnet_init(Chardev *chr);
  81. static void tcp_chr_change_state(SocketChardev *s, TCPChardevState state)
  82. {
  83. switch (state) {
  84. case TCP_CHARDEV_STATE_DISCONNECTED:
  85. break;
  86. case TCP_CHARDEV_STATE_CONNECTING:
  87. assert(s->state == TCP_CHARDEV_STATE_DISCONNECTED);
  88. break;
  89. case TCP_CHARDEV_STATE_CONNECTED:
  90. assert(s->state == TCP_CHARDEV_STATE_CONNECTING);
  91. break;
  92. }
  93. s->state = state;
  94. }
  95. static void tcp_chr_reconn_timer_cancel(SocketChardev *s)
  96. {
  97. if (s->reconnect_timer) {
  98. g_source_destroy(s->reconnect_timer);
  99. g_source_unref(s->reconnect_timer);
  100. s->reconnect_timer = NULL;
  101. }
  102. }
  103. static void qemu_chr_socket_restart_timer(Chardev *chr)
  104. {
  105. SocketChardev *s = SOCKET_CHARDEV(chr);
  106. char *name;
  107. assert(s->state == TCP_CHARDEV_STATE_DISCONNECTED);
  108. assert(!s->reconnect_timer);
  109. name = g_strdup_printf("chardev-socket-reconnect-%s", chr->label);
  110. s->reconnect_timer = qemu_chr_timeout_add_ms(chr,
  111. s->reconnect_time * 1000,
  112. socket_reconnect_timeout,
  113. chr);
  114. g_source_set_name(s->reconnect_timer, name);
  115. g_free(name);
  116. }
  117. static void check_report_connect_error(Chardev *chr,
  118. Error *err)
  119. {
  120. SocketChardev *s = SOCKET_CHARDEV(chr);
  121. if (!s->connect_err_reported) {
  122. error_report("Unable to connect character device %s: %s",
  123. chr->label, error_get_pretty(err));
  124. s->connect_err_reported = true;
  125. }
  126. qemu_chr_socket_restart_timer(chr);
  127. }
  128. static void tcp_chr_accept(QIONetListener *listener,
  129. QIOChannelSocket *cioc,
  130. void *opaque);
  131. static int tcp_chr_read_poll(void *opaque);
  132. static void tcp_chr_disconnect(Chardev *chr);
  133. /* Called with chr_write_lock held. */
  134. static int tcp_chr_write(Chardev *chr, const uint8_t *buf, int len)
  135. {
  136. SocketChardev *s = SOCKET_CHARDEV(chr);
  137. if (s->state == TCP_CHARDEV_STATE_CONNECTED) {
  138. int ret = io_channel_send_full(s->ioc, buf, len,
  139. s->write_msgfds,
  140. s->write_msgfds_num);
  141. /* free the written msgfds in any cases
  142. * other than ret < 0 && errno == EAGAIN
  143. */
  144. if (!(ret < 0 && EAGAIN == errno)
  145. && s->write_msgfds_num) {
  146. g_free(s->write_msgfds);
  147. s->write_msgfds = 0;
  148. s->write_msgfds_num = 0;
  149. }
  150. if (ret < 0 && errno != EAGAIN) {
  151. if (tcp_chr_read_poll(chr) <= 0) {
  152. tcp_chr_disconnect(chr);
  153. return len;
  154. } /* else let the read handler finish it properly */
  155. }
  156. return ret;
  157. } else {
  158. /* XXX: indicate an error ? */
  159. return len;
  160. }
  161. }
  162. static int tcp_chr_read_poll(void *opaque)
  163. {
  164. Chardev *chr = CHARDEV(opaque);
  165. SocketChardev *s = SOCKET_CHARDEV(opaque);
  166. if (s->state != TCP_CHARDEV_STATE_CONNECTED) {
  167. return 0;
  168. }
  169. s->max_size = qemu_chr_be_can_write(chr);
  170. return s->max_size;
  171. }
  172. static void tcp_chr_process_IAC_bytes(Chardev *chr,
  173. SocketChardev *s,
  174. uint8_t *buf, int *size)
  175. {
  176. /* Handle any telnet or tn3270 client's basic IAC options.
  177. * For telnet options, it satisfies char by char mode with no echo.
  178. * For tn3270 options, it satisfies binary mode with EOR.
  179. * All IAC options will be removed from the buf and the do_opt
  180. * pointer will be used to track the state of the width of the
  181. * IAC information.
  182. *
  183. * RFC854: "All TELNET commands consist of at least a two byte sequence.
  184. * The commands dealing with option negotiation are three byte sequences,
  185. * the third byte being the code for the option referenced."
  186. * "IAC BREAK", "IAC IP", "IAC NOP" and the double IAC are two bytes.
  187. * "IAC SB", "IAC SE" and "IAC EOR" are saved to split up data boundary
  188. * for tn3270.
  189. * NOP, Break and Interrupt Process(IP) might be encountered during a TN3270
  190. * session, and NOP and IP need to be done later.
  191. */
  192. int i;
  193. int j = 0;
  194. for (i = 0; i < *size; i++) {
  195. if (s->do_telnetopt > 1) {
  196. if ((unsigned char)buf[i] == IAC && s->do_telnetopt == 2) {
  197. /* Double IAC means send an IAC */
  198. if (j != i) {
  199. buf[j] = buf[i];
  200. }
  201. j++;
  202. s->do_telnetopt = 1;
  203. } else {
  204. if ((unsigned char)buf[i] == IAC_BREAK
  205. && s->do_telnetopt == 2) {
  206. /* Handle IAC break commands by sending a serial break */
  207. qemu_chr_be_event(chr, CHR_EVENT_BREAK);
  208. s->do_telnetopt++;
  209. } else if (s->is_tn3270 && ((unsigned char)buf[i] == IAC_EOR
  210. || (unsigned char)buf[i] == IAC_SB
  211. || (unsigned char)buf[i] == IAC_SE)
  212. && s->do_telnetopt == 2) {
  213. buf[j++] = IAC;
  214. buf[j++] = buf[i];
  215. s->do_telnetopt++;
  216. } else if (s->is_tn3270 && ((unsigned char)buf[i] == IAC_IP
  217. || (unsigned char)buf[i] == IAC_NOP)
  218. && s->do_telnetopt == 2) {
  219. /* TODO: IP and NOP need to be implemented later. */
  220. s->do_telnetopt++;
  221. }
  222. s->do_telnetopt++;
  223. }
  224. if (s->do_telnetopt >= 4) {
  225. s->do_telnetopt = 1;
  226. }
  227. } else {
  228. if ((unsigned char)buf[i] == IAC) {
  229. s->do_telnetopt = 2;
  230. } else {
  231. if (j != i) {
  232. buf[j] = buf[i];
  233. }
  234. j++;
  235. }
  236. }
  237. }
  238. *size = j;
  239. }
  240. static int tcp_get_msgfds(Chardev *chr, int *fds, int num)
  241. {
  242. SocketChardev *s = SOCKET_CHARDEV(chr);
  243. int to_copy = (s->read_msgfds_num < num) ? s->read_msgfds_num : num;
  244. assert(num <= TCP_MAX_FDS);
  245. if (to_copy) {
  246. int i;
  247. memcpy(fds, s->read_msgfds, to_copy * sizeof(int));
  248. /* Close unused fds */
  249. for (i = to_copy; i < s->read_msgfds_num; i++) {
  250. close(s->read_msgfds[i]);
  251. }
  252. g_free(s->read_msgfds);
  253. s->read_msgfds = 0;
  254. s->read_msgfds_num = 0;
  255. }
  256. return to_copy;
  257. }
  258. static int tcp_set_msgfds(Chardev *chr, int *fds, int num)
  259. {
  260. SocketChardev *s = SOCKET_CHARDEV(chr);
  261. /* clear old pending fd array */
  262. g_free(s->write_msgfds);
  263. s->write_msgfds = NULL;
  264. s->write_msgfds_num = 0;
  265. if ((s->state != TCP_CHARDEV_STATE_CONNECTED) ||
  266. !qio_channel_has_feature(s->ioc,
  267. QIO_CHANNEL_FEATURE_FD_PASS)) {
  268. return -1;
  269. }
  270. if (num) {
  271. s->write_msgfds = g_new(int, num);
  272. memcpy(s->write_msgfds, fds, num * sizeof(int));
  273. }
  274. s->write_msgfds_num = num;
  275. return 0;
  276. }
  277. static ssize_t tcp_chr_recv(Chardev *chr, char *buf, size_t len)
  278. {
  279. SocketChardev *s = SOCKET_CHARDEV(chr);
  280. struct iovec iov = { .iov_base = buf, .iov_len = len };
  281. int ret;
  282. size_t i;
  283. int *msgfds = NULL;
  284. size_t msgfds_num = 0;
  285. if (qio_channel_has_feature(s->ioc, QIO_CHANNEL_FEATURE_FD_PASS)) {
  286. ret = qio_channel_readv_full(s->ioc, &iov, 1,
  287. &msgfds, &msgfds_num,
  288. NULL);
  289. } else {
  290. ret = qio_channel_readv_full(s->ioc, &iov, 1,
  291. NULL, NULL,
  292. NULL);
  293. }
  294. if (ret == QIO_CHANNEL_ERR_BLOCK) {
  295. errno = EAGAIN;
  296. ret = -1;
  297. } else if (ret == -1) {
  298. errno = EIO;
  299. }
  300. if (msgfds_num) {
  301. /* close and clean read_msgfds */
  302. for (i = 0; i < s->read_msgfds_num; i++) {
  303. close(s->read_msgfds[i]);
  304. }
  305. if (s->read_msgfds_num) {
  306. g_free(s->read_msgfds);
  307. }
  308. s->read_msgfds = msgfds;
  309. s->read_msgfds_num = msgfds_num;
  310. }
  311. for (i = 0; i < s->read_msgfds_num; i++) {
  312. int fd = s->read_msgfds[i];
  313. if (fd < 0) {
  314. continue;
  315. }
  316. /* O_NONBLOCK is preserved across SCM_RIGHTS so reset it */
  317. qemu_set_block(fd);
  318. #ifndef MSG_CMSG_CLOEXEC
  319. qemu_set_cloexec(fd);
  320. #endif
  321. }
  322. return ret;
  323. }
  324. static GSource *tcp_chr_add_watch(Chardev *chr, GIOCondition cond)
  325. {
  326. SocketChardev *s = SOCKET_CHARDEV(chr);
  327. return qio_channel_create_watch(s->ioc, cond);
  328. }
  329. static void remove_hup_source(SocketChardev *s)
  330. {
  331. if (s->hup_source != NULL) {
  332. g_source_destroy(s->hup_source);
  333. g_source_unref(s->hup_source);
  334. s->hup_source = NULL;
  335. }
  336. }
  337. static void tcp_chr_free_connection(Chardev *chr)
  338. {
  339. SocketChardev *s = SOCKET_CHARDEV(chr);
  340. int i;
  341. if (s->read_msgfds_num) {
  342. for (i = 0; i < s->read_msgfds_num; i++) {
  343. close(s->read_msgfds[i]);
  344. }
  345. g_free(s->read_msgfds);
  346. s->read_msgfds = NULL;
  347. s->read_msgfds_num = 0;
  348. }
  349. remove_hup_source(s);
  350. tcp_set_msgfds(chr, NULL, 0);
  351. remove_fd_in_watch(chr);
  352. object_unref(OBJECT(s->sioc));
  353. s->sioc = NULL;
  354. object_unref(OBJECT(s->ioc));
  355. s->ioc = NULL;
  356. g_free(chr->filename);
  357. chr->filename = NULL;
  358. tcp_chr_change_state(s, TCP_CHARDEV_STATE_DISCONNECTED);
  359. }
  360. static const char *qemu_chr_socket_protocol(SocketChardev *s)
  361. {
  362. if (s->is_telnet) {
  363. return "telnet";
  364. }
  365. return s->is_websock ? "websocket" : "tcp";
  366. }
  367. static char *qemu_chr_socket_address(SocketChardev *s, const char *prefix)
  368. {
  369. switch (s->addr->type) {
  370. case SOCKET_ADDRESS_TYPE_INET:
  371. return g_strdup_printf("%s%s:%s:%s%s", prefix,
  372. qemu_chr_socket_protocol(s),
  373. s->addr->u.inet.host,
  374. s->addr->u.inet.port,
  375. s->is_listen ? ",server" : "");
  376. break;
  377. case SOCKET_ADDRESS_TYPE_UNIX:
  378. return g_strdup_printf("%sunix:%s%s", prefix,
  379. s->addr->u.q_unix.path,
  380. s->is_listen ? ",server" : "");
  381. break;
  382. case SOCKET_ADDRESS_TYPE_FD:
  383. return g_strdup_printf("%sfd:%s%s", prefix, s->addr->u.fd.str,
  384. s->is_listen ? ",server" : "");
  385. break;
  386. case SOCKET_ADDRESS_TYPE_VSOCK:
  387. return g_strdup_printf("%svsock:%s:%s", prefix,
  388. s->addr->u.vsock.cid,
  389. s->addr->u.vsock.port);
  390. default:
  391. abort();
  392. }
  393. }
  394. static void update_disconnected_filename(SocketChardev *s)
  395. {
  396. Chardev *chr = CHARDEV(s);
  397. g_free(chr->filename);
  398. if (s->addr) {
  399. chr->filename = qemu_chr_socket_address(s, "disconnected:");
  400. } else {
  401. chr->filename = g_strdup("disconnected:socket");
  402. }
  403. }
  404. /* NB may be called even if tcp_chr_connect has not been
  405. * reached, due to TLS or telnet initialization failure,
  406. * so can *not* assume s->state == TCP_CHARDEV_STATE_CONNECTED
  407. */
  408. static void tcp_chr_disconnect(Chardev *chr)
  409. {
  410. SocketChardev *s = SOCKET_CHARDEV(chr);
  411. bool emit_close = s->state == TCP_CHARDEV_STATE_CONNECTED;
  412. tcp_chr_free_connection(chr);
  413. if (s->listener) {
  414. qio_net_listener_set_client_func_full(s->listener, tcp_chr_accept,
  415. chr, NULL, chr->gcontext);
  416. }
  417. update_disconnected_filename(s);
  418. if (emit_close) {
  419. qemu_chr_be_event(chr, CHR_EVENT_CLOSED);
  420. }
  421. if (s->reconnect_time) {
  422. qemu_chr_socket_restart_timer(chr);
  423. }
  424. }
  425. static gboolean tcp_chr_read(QIOChannel *chan, GIOCondition cond, void *opaque)
  426. {
  427. Chardev *chr = CHARDEV(opaque);
  428. SocketChardev *s = SOCKET_CHARDEV(opaque);
  429. uint8_t buf[CHR_READ_BUF_LEN];
  430. int len, size;
  431. if ((s->state != TCP_CHARDEV_STATE_CONNECTED) ||
  432. s->max_size <= 0) {
  433. return TRUE;
  434. }
  435. len = sizeof(buf);
  436. if (len > s->max_size) {
  437. len = s->max_size;
  438. }
  439. size = tcp_chr_recv(chr, (void *)buf, len);
  440. if (size == 0 || (size == -1 && errno != EAGAIN)) {
  441. /* connection closed */
  442. tcp_chr_disconnect(chr);
  443. } else if (size > 0) {
  444. if (s->do_telnetopt) {
  445. tcp_chr_process_IAC_bytes(chr, s, buf, &size);
  446. }
  447. if (size > 0) {
  448. qemu_chr_be_write(chr, buf, size);
  449. }
  450. }
  451. return TRUE;
  452. }
  453. static gboolean tcp_chr_hup(QIOChannel *channel,
  454. GIOCondition cond,
  455. void *opaque)
  456. {
  457. Chardev *chr = CHARDEV(opaque);
  458. tcp_chr_disconnect(chr);
  459. return G_SOURCE_REMOVE;
  460. }
  461. static int tcp_chr_sync_read(Chardev *chr, const uint8_t *buf, int len)
  462. {
  463. SocketChardev *s = SOCKET_CHARDEV(chr);
  464. int size;
  465. if (s->state != TCP_CHARDEV_STATE_CONNECTED) {
  466. return 0;
  467. }
  468. qio_channel_set_blocking(s->ioc, true, NULL);
  469. size = tcp_chr_recv(chr, (void *) buf, len);
  470. qio_channel_set_blocking(s->ioc, false, NULL);
  471. if (size == 0) {
  472. /* connection closed */
  473. tcp_chr_disconnect(chr);
  474. }
  475. return size;
  476. }
  477. static char *qemu_chr_compute_filename(SocketChardev *s)
  478. {
  479. struct sockaddr_storage *ss = &s->sioc->localAddr;
  480. struct sockaddr_storage *ps = &s->sioc->remoteAddr;
  481. socklen_t ss_len = s->sioc->localAddrLen;
  482. socklen_t ps_len = s->sioc->remoteAddrLen;
  483. char shost[NI_MAXHOST], sserv[NI_MAXSERV];
  484. char phost[NI_MAXHOST], pserv[NI_MAXSERV];
  485. const char *left = "", *right = "";
  486. switch (ss->ss_family) {
  487. #ifndef _WIN32
  488. case AF_UNIX:
  489. return g_strdup_printf("unix:%s%s",
  490. ((struct sockaddr_un *)(ss))->sun_path,
  491. s->is_listen ? ",server" : "");
  492. #endif
  493. case AF_INET6:
  494. left = "[";
  495. right = "]";
  496. /* fall through */
  497. case AF_INET:
  498. getnameinfo((struct sockaddr *) ss, ss_len, shost, sizeof(shost),
  499. sserv, sizeof(sserv), NI_NUMERICHOST | NI_NUMERICSERV);
  500. getnameinfo((struct sockaddr *) ps, ps_len, phost, sizeof(phost),
  501. pserv, sizeof(pserv), NI_NUMERICHOST | NI_NUMERICSERV);
  502. return g_strdup_printf("%s:%s%s%s:%s%s <-> %s%s%s:%s",
  503. qemu_chr_socket_protocol(s),
  504. left, shost, right, sserv,
  505. s->is_listen ? ",server" : "",
  506. left, phost, right, pserv);
  507. default:
  508. return g_strdup_printf("unknown");
  509. }
  510. }
  511. static void update_ioc_handlers(SocketChardev *s)
  512. {
  513. Chardev *chr = CHARDEV(s);
  514. if (s->state != TCP_CHARDEV_STATE_CONNECTED) {
  515. return;
  516. }
  517. remove_fd_in_watch(chr);
  518. chr->gsource = io_add_watch_poll(chr, s->ioc,
  519. tcp_chr_read_poll,
  520. tcp_chr_read, chr,
  521. chr->gcontext);
  522. remove_hup_source(s);
  523. s->hup_source = qio_channel_create_watch(s->ioc, G_IO_HUP);
  524. g_source_set_callback(s->hup_source, (GSourceFunc)tcp_chr_hup,
  525. chr, NULL);
  526. g_source_attach(s->hup_source, chr->gcontext);
  527. }
  528. static void tcp_chr_connect(void *opaque)
  529. {
  530. Chardev *chr = CHARDEV(opaque);
  531. SocketChardev *s = SOCKET_CHARDEV(opaque);
  532. g_free(chr->filename);
  533. chr->filename = qemu_chr_compute_filename(s);
  534. tcp_chr_change_state(s, TCP_CHARDEV_STATE_CONNECTED);
  535. update_ioc_handlers(s);
  536. qemu_chr_be_event(chr, CHR_EVENT_OPENED);
  537. }
  538. static void tcp_chr_telnet_destroy(SocketChardev *s)
  539. {
  540. if (s->telnet_source) {
  541. g_source_destroy(s->telnet_source);
  542. g_source_unref(s->telnet_source);
  543. s->telnet_source = NULL;
  544. }
  545. }
  546. static void tcp_chr_update_read_handler(Chardev *chr)
  547. {
  548. SocketChardev *s = SOCKET_CHARDEV(chr);
  549. if (s->listener && s->state == TCP_CHARDEV_STATE_DISCONNECTED) {
  550. /*
  551. * It's possible that chardev context is changed in
  552. * qemu_chr_be_update_read_handlers(). Reset it for QIO net
  553. * listener if there is.
  554. */
  555. qio_net_listener_set_client_func_full(s->listener, tcp_chr_accept,
  556. chr, NULL, chr->gcontext);
  557. }
  558. if (s->telnet_source) {
  559. tcp_chr_telnet_init(CHARDEV(s));
  560. }
  561. update_ioc_handlers(s);
  562. }
  563. static gboolean tcp_chr_telnet_init_io(QIOChannel *ioc,
  564. GIOCondition cond G_GNUC_UNUSED,
  565. gpointer user_data)
  566. {
  567. SocketChardev *s = user_data;
  568. Chardev *chr = CHARDEV(s);
  569. TCPChardevTelnetInit *init = s->telnet_init;
  570. ssize_t ret;
  571. assert(init);
  572. ret = qio_channel_write(ioc, init->buf, init->buflen, NULL);
  573. if (ret < 0) {
  574. if (ret == QIO_CHANNEL_ERR_BLOCK) {
  575. ret = 0;
  576. } else {
  577. tcp_chr_disconnect(chr);
  578. goto end;
  579. }
  580. }
  581. init->buflen -= ret;
  582. if (init->buflen == 0) {
  583. tcp_chr_connect(chr);
  584. goto end;
  585. }
  586. memmove(init->buf, init->buf + ret, init->buflen);
  587. return G_SOURCE_CONTINUE;
  588. end:
  589. g_free(s->telnet_init);
  590. s->telnet_init = NULL;
  591. g_source_unref(s->telnet_source);
  592. s->telnet_source = NULL;
  593. return G_SOURCE_REMOVE;
  594. }
  595. static void tcp_chr_telnet_init(Chardev *chr)
  596. {
  597. SocketChardev *s = SOCKET_CHARDEV(chr);
  598. TCPChardevTelnetInit *init;
  599. size_t n = 0;
  600. /* Destroy existing task */
  601. tcp_chr_telnet_destroy(s);
  602. if (s->telnet_init) {
  603. /* We are possibly during a handshake already */
  604. goto cont;
  605. }
  606. s->telnet_init = g_new0(TCPChardevTelnetInit, 1);
  607. init = s->telnet_init;
  608. #define IACSET(x, a, b, c) \
  609. do { \
  610. x[n++] = a; \
  611. x[n++] = b; \
  612. x[n++] = c; \
  613. } while (0)
  614. if (!s->is_tn3270) {
  615. init->buflen = 12;
  616. /* Prep the telnet negotion to put telnet in binary,
  617. * no echo, single char mode */
  618. IACSET(init->buf, 0xff, 0xfb, 0x01); /* IAC WILL ECHO */
  619. IACSET(init->buf, 0xff, 0xfb, 0x03); /* IAC WILL Suppress go ahead */
  620. IACSET(init->buf, 0xff, 0xfb, 0x00); /* IAC WILL Binary */
  621. IACSET(init->buf, 0xff, 0xfd, 0x00); /* IAC DO Binary */
  622. } else {
  623. init->buflen = 21;
  624. /* Prep the TN3270 negotion based on RFC1576 */
  625. IACSET(init->buf, 0xff, 0xfd, 0x19); /* IAC DO EOR */
  626. IACSET(init->buf, 0xff, 0xfb, 0x19); /* IAC WILL EOR */
  627. IACSET(init->buf, 0xff, 0xfd, 0x00); /* IAC DO BINARY */
  628. IACSET(init->buf, 0xff, 0xfb, 0x00); /* IAC WILL BINARY */
  629. IACSET(init->buf, 0xff, 0xfd, 0x18); /* IAC DO TERMINAL TYPE */
  630. IACSET(init->buf, 0xff, 0xfa, 0x18); /* IAC SB TERMINAL TYPE */
  631. IACSET(init->buf, 0x01, 0xff, 0xf0); /* SEND IAC SE */
  632. }
  633. #undef IACSET
  634. cont:
  635. s->telnet_source = qio_channel_add_watch_source(s->ioc, G_IO_OUT,
  636. tcp_chr_telnet_init_io,
  637. s, NULL,
  638. chr->gcontext);
  639. }
  640. static void tcp_chr_websock_handshake(QIOTask *task, gpointer user_data)
  641. {
  642. Chardev *chr = user_data;
  643. SocketChardev *s = user_data;
  644. if (qio_task_propagate_error(task, NULL)) {
  645. tcp_chr_disconnect(chr);
  646. } else {
  647. if (s->do_telnetopt) {
  648. tcp_chr_telnet_init(chr);
  649. } else {
  650. tcp_chr_connect(chr);
  651. }
  652. }
  653. }
  654. static void tcp_chr_websock_init(Chardev *chr)
  655. {
  656. SocketChardev *s = SOCKET_CHARDEV(chr);
  657. QIOChannelWebsock *wioc = NULL;
  658. gchar *name;
  659. wioc = qio_channel_websock_new_server(s->ioc);
  660. name = g_strdup_printf("chardev-websocket-server-%s", chr->label);
  661. qio_channel_set_name(QIO_CHANNEL(wioc), name);
  662. g_free(name);
  663. object_unref(OBJECT(s->ioc));
  664. s->ioc = QIO_CHANNEL(wioc);
  665. qio_channel_websock_handshake(wioc, tcp_chr_websock_handshake, chr, NULL);
  666. }
  667. static void tcp_chr_tls_handshake(QIOTask *task,
  668. gpointer user_data)
  669. {
  670. Chardev *chr = user_data;
  671. SocketChardev *s = user_data;
  672. if (qio_task_propagate_error(task, NULL)) {
  673. tcp_chr_disconnect(chr);
  674. } else {
  675. if (s->is_websock) {
  676. tcp_chr_websock_init(chr);
  677. } else if (s->do_telnetopt) {
  678. tcp_chr_telnet_init(chr);
  679. } else {
  680. tcp_chr_connect(chr);
  681. }
  682. }
  683. }
  684. static void tcp_chr_tls_init(Chardev *chr)
  685. {
  686. SocketChardev *s = SOCKET_CHARDEV(chr);
  687. QIOChannelTLS *tioc;
  688. Error *err = NULL;
  689. gchar *name;
  690. if (s->is_listen) {
  691. tioc = qio_channel_tls_new_server(
  692. s->ioc, s->tls_creds,
  693. s->tls_authz,
  694. &err);
  695. } else {
  696. tioc = qio_channel_tls_new_client(
  697. s->ioc, s->tls_creds,
  698. s->addr->u.inet.host,
  699. &err);
  700. }
  701. if (tioc == NULL) {
  702. error_free(err);
  703. tcp_chr_disconnect(chr);
  704. return;
  705. }
  706. name = g_strdup_printf("chardev-tls-%s-%s",
  707. s->is_listen ? "server" : "client",
  708. chr->label);
  709. qio_channel_set_name(QIO_CHANNEL(tioc), name);
  710. g_free(name);
  711. object_unref(OBJECT(s->ioc));
  712. s->ioc = QIO_CHANNEL(tioc);
  713. qio_channel_tls_handshake(tioc,
  714. tcp_chr_tls_handshake,
  715. chr,
  716. NULL,
  717. chr->gcontext);
  718. }
  719. static void tcp_chr_set_client_ioc_name(Chardev *chr,
  720. QIOChannelSocket *sioc)
  721. {
  722. SocketChardev *s = SOCKET_CHARDEV(chr);
  723. char *name;
  724. name = g_strdup_printf("chardev-tcp-%s-%s",
  725. s->is_listen ? "server" : "client",
  726. chr->label);
  727. qio_channel_set_name(QIO_CHANNEL(sioc), name);
  728. g_free(name);
  729. }
  730. static int tcp_chr_new_client(Chardev *chr, QIOChannelSocket *sioc)
  731. {
  732. SocketChardev *s = SOCKET_CHARDEV(chr);
  733. if (s->state != TCP_CHARDEV_STATE_CONNECTING) {
  734. return -1;
  735. }
  736. s->ioc = QIO_CHANNEL(sioc);
  737. object_ref(OBJECT(sioc));
  738. s->sioc = sioc;
  739. object_ref(OBJECT(sioc));
  740. qio_channel_set_blocking(s->ioc, false, NULL);
  741. if (s->do_nodelay) {
  742. qio_channel_set_delay(s->ioc, false);
  743. }
  744. if (s->listener) {
  745. qio_net_listener_set_client_func_full(s->listener, NULL, NULL,
  746. NULL, chr->gcontext);
  747. }
  748. if (s->tls_creds) {
  749. tcp_chr_tls_init(chr);
  750. } else if (s->is_websock) {
  751. tcp_chr_websock_init(chr);
  752. } else if (s->do_telnetopt) {
  753. tcp_chr_telnet_init(chr);
  754. } else {
  755. tcp_chr_connect(chr);
  756. }
  757. return 0;
  758. }
  759. static int tcp_chr_add_client(Chardev *chr, int fd)
  760. {
  761. int ret;
  762. QIOChannelSocket *sioc;
  763. SocketChardev *s = SOCKET_CHARDEV(chr);
  764. if (s->state != TCP_CHARDEV_STATE_DISCONNECTED) {
  765. return -1;
  766. }
  767. sioc = qio_channel_socket_new_fd(fd, NULL);
  768. if (!sioc) {
  769. return -1;
  770. }
  771. tcp_chr_change_state(s, TCP_CHARDEV_STATE_CONNECTING);
  772. tcp_chr_set_client_ioc_name(chr, sioc);
  773. ret = tcp_chr_new_client(chr, sioc);
  774. object_unref(OBJECT(sioc));
  775. return ret;
  776. }
  777. static void tcp_chr_accept(QIONetListener *listener,
  778. QIOChannelSocket *cioc,
  779. void *opaque)
  780. {
  781. Chardev *chr = CHARDEV(opaque);
  782. SocketChardev *s = SOCKET_CHARDEV(chr);
  783. tcp_chr_change_state(s, TCP_CHARDEV_STATE_CONNECTING);
  784. tcp_chr_set_client_ioc_name(chr, cioc);
  785. tcp_chr_new_client(chr, cioc);
  786. }
  787. static int tcp_chr_connect_client_sync(Chardev *chr, Error **errp)
  788. {
  789. SocketChardev *s = SOCKET_CHARDEV(chr);
  790. QIOChannelSocket *sioc = qio_channel_socket_new();
  791. tcp_chr_change_state(s, TCP_CHARDEV_STATE_CONNECTING);
  792. tcp_chr_set_client_ioc_name(chr, sioc);
  793. if (qio_channel_socket_connect_sync(sioc, s->addr, errp) < 0) {
  794. tcp_chr_change_state(s, TCP_CHARDEV_STATE_DISCONNECTED);
  795. object_unref(OBJECT(sioc));
  796. return -1;
  797. }
  798. tcp_chr_new_client(chr, sioc);
  799. object_unref(OBJECT(sioc));
  800. return 0;
  801. }
  802. static void tcp_chr_accept_server_sync(Chardev *chr)
  803. {
  804. SocketChardev *s = SOCKET_CHARDEV(chr);
  805. QIOChannelSocket *sioc;
  806. info_report("QEMU waiting for connection on: %s",
  807. chr->filename);
  808. tcp_chr_change_state(s, TCP_CHARDEV_STATE_CONNECTING);
  809. sioc = qio_net_listener_wait_client(s->listener);
  810. tcp_chr_set_client_ioc_name(chr, sioc);
  811. tcp_chr_new_client(chr, sioc);
  812. object_unref(OBJECT(sioc));
  813. }
  814. static int tcp_chr_wait_connected(Chardev *chr, Error **errp)
  815. {
  816. SocketChardev *s = SOCKET_CHARDEV(chr);
  817. const char *opts[] = { "telnet", "tn3270", "websock", "tls-creds" };
  818. bool optset[] = { s->is_telnet, s->is_tn3270, s->is_websock, s->tls_creds };
  819. size_t i;
  820. QEMU_BUILD_BUG_ON(G_N_ELEMENTS(opts) != G_N_ELEMENTS(optset));
  821. for (i = 0; i < G_N_ELEMENTS(opts); i++) {
  822. if (optset[i]) {
  823. error_setg(errp,
  824. "'%s' option is incompatible with waiting for "
  825. "connection completion", opts[i]);
  826. return -1;
  827. }
  828. }
  829. tcp_chr_reconn_timer_cancel(s);
  830. /*
  831. * We expect states to be as follows:
  832. *
  833. * - server
  834. * - wait -> CONNECTED
  835. * - nowait -> DISCONNECTED
  836. * - client
  837. * - reconnect == 0 -> CONNECTED
  838. * - reconnect != 0 -> CONNECTING
  839. *
  840. */
  841. if (s->state == TCP_CHARDEV_STATE_CONNECTING) {
  842. if (!s->connect_task) {
  843. error_setg(errp,
  844. "Unexpected 'connecting' state without connect task "
  845. "while waiting for connection completion");
  846. return -1;
  847. }
  848. /*
  849. * tcp_chr_wait_connected should only ever be run from the
  850. * main loop thread associated with chr->gcontext, otherwise
  851. * qio_task_wait_thread has a dangerous race condition with
  852. * free'ing of the s->connect_task object.
  853. *
  854. * Acquiring the main context doesn't 100% prove we're in
  855. * the main loop thread, but it does at least guarantee
  856. * that the main loop won't be executed by another thread
  857. * avoiding the race condition with the task idle callback.
  858. */
  859. g_main_context_acquire(chr->gcontext);
  860. qio_task_wait_thread(s->connect_task);
  861. g_main_context_release(chr->gcontext);
  862. /*
  863. * The completion callback (qemu_chr_socket_connected) for
  864. * s->connect_task should have set this to NULL by the time
  865. * qio_task_wait_thread has returned.
  866. */
  867. assert(!s->connect_task);
  868. /*
  869. * NB we are *not* guaranteed to have "s->state == ..CONNECTED"
  870. * at this point as this first connect may be failed, so
  871. * allow the next loop to run regardless.
  872. */
  873. }
  874. while (s->state != TCP_CHARDEV_STATE_CONNECTED) {
  875. if (s->is_listen) {
  876. tcp_chr_accept_server_sync(chr);
  877. } else {
  878. Error *err = NULL;
  879. if (tcp_chr_connect_client_sync(chr, &err) < 0) {
  880. if (s->reconnect_time) {
  881. error_free(err);
  882. g_usleep(s->reconnect_time * 1000ULL * 1000ULL);
  883. } else {
  884. error_propagate(errp, err);
  885. return -1;
  886. }
  887. }
  888. }
  889. }
  890. return 0;
  891. }
  892. static void char_socket_finalize(Object *obj)
  893. {
  894. Chardev *chr = CHARDEV(obj);
  895. SocketChardev *s = SOCKET_CHARDEV(obj);
  896. tcp_chr_free_connection(chr);
  897. tcp_chr_reconn_timer_cancel(s);
  898. qapi_free_SocketAddress(s->addr);
  899. tcp_chr_telnet_destroy(s);
  900. g_free(s->telnet_init);
  901. if (s->listener) {
  902. qio_net_listener_set_client_func_full(s->listener, NULL, NULL,
  903. NULL, chr->gcontext);
  904. object_unref(OBJECT(s->listener));
  905. }
  906. if (s->tls_creds) {
  907. object_unref(OBJECT(s->tls_creds));
  908. }
  909. g_free(s->tls_authz);
  910. qemu_chr_be_event(chr, CHR_EVENT_CLOSED);
  911. }
  912. static void qemu_chr_socket_connected(QIOTask *task, void *opaque)
  913. {
  914. QIOChannelSocket *sioc = QIO_CHANNEL_SOCKET(qio_task_get_source(task));
  915. Chardev *chr = CHARDEV(opaque);
  916. SocketChardev *s = SOCKET_CHARDEV(chr);
  917. Error *err = NULL;
  918. s->connect_task = NULL;
  919. if (qio_task_propagate_error(task, &err)) {
  920. tcp_chr_change_state(s, TCP_CHARDEV_STATE_DISCONNECTED);
  921. check_report_connect_error(chr, err);
  922. error_free(err);
  923. goto cleanup;
  924. }
  925. s->connect_err_reported = false;
  926. tcp_chr_new_client(chr, sioc);
  927. cleanup:
  928. object_unref(OBJECT(sioc));
  929. }
  930. static void tcp_chr_connect_client_task(QIOTask *task,
  931. gpointer opaque)
  932. {
  933. QIOChannelSocket *ioc = QIO_CHANNEL_SOCKET(qio_task_get_source(task));
  934. SocketAddress *addr = opaque;
  935. Error *err = NULL;
  936. qio_channel_socket_connect_sync(ioc, addr, &err);
  937. qio_task_set_error(task, err);
  938. }
  939. static void tcp_chr_connect_client_async(Chardev *chr)
  940. {
  941. SocketChardev *s = SOCKET_CHARDEV(chr);
  942. QIOChannelSocket *sioc;
  943. tcp_chr_change_state(s, TCP_CHARDEV_STATE_CONNECTING);
  944. sioc = qio_channel_socket_new();
  945. tcp_chr_set_client_ioc_name(chr, sioc);
  946. /*
  947. * Normally code would use the qio_channel_socket_connect_async
  948. * method which uses a QIOTask + qio_task_set_error internally
  949. * to avoid blocking. The tcp_chr_wait_connected method, however,
  950. * needs a way to synchronize with completion of the background
  951. * connect task which can't be done with the QIOChannelSocket
  952. * async APIs. Thus we must use QIOTask directly to implement
  953. * the non-blocking concept locally.
  954. */
  955. s->connect_task = qio_task_new(OBJECT(sioc),
  956. qemu_chr_socket_connected,
  957. chr, NULL);
  958. qio_task_run_in_thread(s->connect_task,
  959. tcp_chr_connect_client_task,
  960. s->addr,
  961. NULL,
  962. chr->gcontext);
  963. }
  964. static gboolean socket_reconnect_timeout(gpointer opaque)
  965. {
  966. Chardev *chr = CHARDEV(opaque);
  967. SocketChardev *s = SOCKET_CHARDEV(opaque);
  968. g_source_unref(s->reconnect_timer);
  969. s->reconnect_timer = NULL;
  970. if (chr->be_open) {
  971. return false;
  972. }
  973. tcp_chr_connect_client_async(chr);
  974. return false;
  975. }
  976. static int qmp_chardev_open_socket_server(Chardev *chr,
  977. bool is_telnet,
  978. bool is_waitconnect,
  979. Error **errp)
  980. {
  981. SocketChardev *s = SOCKET_CHARDEV(chr);
  982. char *name;
  983. if (is_telnet) {
  984. s->do_telnetopt = 1;
  985. }
  986. s->listener = qio_net_listener_new();
  987. name = g_strdup_printf("chardev-tcp-listener-%s", chr->label);
  988. qio_net_listener_set_name(s->listener, name);
  989. g_free(name);
  990. if (qio_net_listener_open_sync(s->listener, s->addr, errp) < 0) {
  991. object_unref(OBJECT(s->listener));
  992. s->listener = NULL;
  993. return -1;
  994. }
  995. qapi_free_SocketAddress(s->addr);
  996. s->addr = socket_local_address(s->listener->sioc[0]->fd, errp);
  997. update_disconnected_filename(s);
  998. if (is_waitconnect) {
  999. tcp_chr_accept_server_sync(chr);
  1000. } else {
  1001. qio_net_listener_set_client_func_full(s->listener,
  1002. tcp_chr_accept,
  1003. chr, NULL,
  1004. chr->gcontext);
  1005. }
  1006. return 0;
  1007. }
  1008. static int qmp_chardev_open_socket_client(Chardev *chr,
  1009. int64_t reconnect,
  1010. Error **errp)
  1011. {
  1012. SocketChardev *s = SOCKET_CHARDEV(chr);
  1013. if (reconnect > 0) {
  1014. s->reconnect_time = reconnect;
  1015. tcp_chr_connect_client_async(chr);
  1016. return 0;
  1017. } else {
  1018. return tcp_chr_connect_client_sync(chr, errp);
  1019. }
  1020. }
  1021. static bool qmp_chardev_validate_socket(ChardevSocket *sock,
  1022. SocketAddress *addr,
  1023. Error **errp)
  1024. {
  1025. /* Validate any options which have a dependency on address type */
  1026. switch (addr->type) {
  1027. case SOCKET_ADDRESS_TYPE_FD:
  1028. if (sock->has_reconnect) {
  1029. error_setg(errp,
  1030. "'reconnect' option is incompatible with "
  1031. "'fd' address type");
  1032. return false;
  1033. }
  1034. if (sock->has_tls_creds &&
  1035. !(sock->has_server && sock->server)) {
  1036. error_setg(errp,
  1037. "'tls_creds' option is incompatible with "
  1038. "'fd' address type as client");
  1039. return false;
  1040. }
  1041. break;
  1042. case SOCKET_ADDRESS_TYPE_UNIX:
  1043. if (sock->has_tls_creds) {
  1044. error_setg(errp,
  1045. "'tls_creds' option is incompatible with "
  1046. "'unix' address type");
  1047. return false;
  1048. }
  1049. break;
  1050. case SOCKET_ADDRESS_TYPE_INET:
  1051. break;
  1052. case SOCKET_ADDRESS_TYPE_VSOCK:
  1053. if (sock->has_tls_creds) {
  1054. error_setg(errp,
  1055. "'tls_creds' option is incompatible with "
  1056. "'vsock' address type");
  1057. return false;
  1058. }
  1059. default:
  1060. break;
  1061. }
  1062. if (sock->has_tls_authz && !sock->has_tls_creds) {
  1063. error_setg(errp, "'tls_authz' option requires 'tls_creds' option");
  1064. return false;
  1065. }
  1066. /* Validate any options which have a dependancy on client vs server */
  1067. if (!sock->has_server || sock->server) {
  1068. if (sock->has_reconnect) {
  1069. error_setg(errp,
  1070. "'reconnect' option is incompatible with "
  1071. "socket in server listen mode");
  1072. return false;
  1073. }
  1074. } else {
  1075. if (sock->has_websocket && sock->websocket) {
  1076. error_setg(errp, "%s", "Websocket client is not implemented");
  1077. return false;
  1078. }
  1079. if (sock->has_wait) {
  1080. warn_report("'wait' option is deprecated with "
  1081. "socket in client connect mode");
  1082. if (sock->wait) {
  1083. error_setg(errp, "%s",
  1084. "'wait' option is incompatible with "
  1085. "socket in client connect mode");
  1086. return false;
  1087. }
  1088. }
  1089. }
  1090. return true;
  1091. }
  1092. static void qmp_chardev_open_socket(Chardev *chr,
  1093. ChardevBackend *backend,
  1094. bool *be_opened,
  1095. Error **errp)
  1096. {
  1097. SocketChardev *s = SOCKET_CHARDEV(chr);
  1098. ChardevSocket *sock = backend->u.socket.data;
  1099. bool do_nodelay = sock->has_nodelay ? sock->nodelay : false;
  1100. bool is_listen = sock->has_server ? sock->server : true;
  1101. bool is_telnet = sock->has_telnet ? sock->telnet : false;
  1102. bool is_tn3270 = sock->has_tn3270 ? sock->tn3270 : false;
  1103. bool is_waitconnect = sock->has_wait ? sock->wait : false;
  1104. bool is_websock = sock->has_websocket ? sock->websocket : false;
  1105. int64_t reconnect = sock->has_reconnect ? sock->reconnect : 0;
  1106. SocketAddress *addr;
  1107. s->is_listen = is_listen;
  1108. s->is_telnet = is_telnet;
  1109. s->is_tn3270 = is_tn3270;
  1110. s->is_websock = is_websock;
  1111. s->do_nodelay = do_nodelay;
  1112. if (sock->tls_creds) {
  1113. Object *creds;
  1114. creds = object_resolve_path_component(
  1115. object_get_objects_root(), sock->tls_creds);
  1116. if (!creds) {
  1117. error_setg(errp, "No TLS credentials with id '%s'",
  1118. sock->tls_creds);
  1119. return;
  1120. }
  1121. s->tls_creds = (QCryptoTLSCreds *)
  1122. object_dynamic_cast(creds,
  1123. TYPE_QCRYPTO_TLS_CREDS);
  1124. if (!s->tls_creds) {
  1125. error_setg(errp, "Object with id '%s' is not TLS credentials",
  1126. sock->tls_creds);
  1127. return;
  1128. }
  1129. object_ref(OBJECT(s->tls_creds));
  1130. if (is_listen) {
  1131. if (s->tls_creds->endpoint != QCRYPTO_TLS_CREDS_ENDPOINT_SERVER) {
  1132. error_setg(errp, "%s",
  1133. "Expected TLS credentials for server endpoint");
  1134. return;
  1135. }
  1136. } else {
  1137. if (s->tls_creds->endpoint != QCRYPTO_TLS_CREDS_ENDPOINT_CLIENT) {
  1138. error_setg(errp, "%s",
  1139. "Expected TLS credentials for client endpoint");
  1140. return;
  1141. }
  1142. }
  1143. }
  1144. s->tls_authz = g_strdup(sock->tls_authz);
  1145. s->addr = addr = socket_address_flatten(sock->addr);
  1146. if (!qmp_chardev_validate_socket(sock, addr, errp)) {
  1147. return;
  1148. }
  1149. qemu_chr_set_feature(chr, QEMU_CHAR_FEATURE_RECONNECTABLE);
  1150. /* TODO SOCKET_ADDRESS_FD where fd has AF_UNIX */
  1151. if (addr->type == SOCKET_ADDRESS_TYPE_UNIX) {
  1152. qemu_chr_set_feature(chr, QEMU_CHAR_FEATURE_FD_PASS);
  1153. }
  1154. /* be isn't opened until we get a connection */
  1155. *be_opened = false;
  1156. update_disconnected_filename(s);
  1157. if (s->is_listen) {
  1158. if (qmp_chardev_open_socket_server(chr, is_telnet || is_tn3270,
  1159. is_waitconnect, errp) < 0) {
  1160. return;
  1161. }
  1162. } else {
  1163. if (qmp_chardev_open_socket_client(chr, reconnect, errp) < 0) {
  1164. return;
  1165. }
  1166. }
  1167. }
  1168. static void qemu_chr_parse_socket(QemuOpts *opts, ChardevBackend *backend,
  1169. Error **errp)
  1170. {
  1171. const char *path = qemu_opt_get(opts, "path");
  1172. const char *host = qemu_opt_get(opts, "host");
  1173. const char *port = qemu_opt_get(opts, "port");
  1174. const char *fd = qemu_opt_get(opts, "fd");
  1175. SocketAddressLegacy *addr;
  1176. ChardevSocket *sock;
  1177. if ((!!path + !!fd + !!host) != 1) {
  1178. error_setg(errp,
  1179. "Exactly one of 'path', 'fd' or 'host' required");
  1180. return;
  1181. }
  1182. if (host && !port) {
  1183. error_setg(errp, "chardev: socket: no port given");
  1184. return;
  1185. }
  1186. backend->type = CHARDEV_BACKEND_KIND_SOCKET;
  1187. sock = backend->u.socket.data = g_new0(ChardevSocket, 1);
  1188. qemu_chr_parse_common(opts, qapi_ChardevSocket_base(sock));
  1189. sock->has_nodelay = qemu_opt_get(opts, "delay");
  1190. sock->nodelay = !qemu_opt_get_bool(opts, "delay", true);
  1191. /*
  1192. * We have different default to QMP for 'server', hence
  1193. * we can't just check for existence of 'server'
  1194. */
  1195. sock->has_server = true;
  1196. sock->server = qemu_opt_get_bool(opts, "server", false);
  1197. sock->has_telnet = qemu_opt_get(opts, "telnet");
  1198. sock->telnet = qemu_opt_get_bool(opts, "telnet", false);
  1199. sock->has_tn3270 = qemu_opt_get(opts, "tn3270");
  1200. sock->tn3270 = qemu_opt_get_bool(opts, "tn3270", false);
  1201. sock->has_websocket = qemu_opt_get(opts, "websocket");
  1202. sock->websocket = qemu_opt_get_bool(opts, "websocket", false);
  1203. /*
  1204. * We have different default to QMP for 'wait' when 'server'
  1205. * is set, hence we can't just check for existence of 'wait'
  1206. */
  1207. sock->has_wait = qemu_opt_find(opts, "wait") || sock->server;
  1208. sock->wait = qemu_opt_get_bool(opts, "wait", true);
  1209. sock->has_reconnect = qemu_opt_find(opts, "reconnect");
  1210. sock->reconnect = qemu_opt_get_number(opts, "reconnect", 0);
  1211. sock->has_tls_creds = qemu_opt_get(opts, "tls-creds");
  1212. sock->tls_creds = g_strdup(qemu_opt_get(opts, "tls-creds"));
  1213. sock->has_tls_authz = qemu_opt_get(opts, "tls-authz");
  1214. sock->tls_authz = g_strdup(qemu_opt_get(opts, "tls-authz"));
  1215. addr = g_new0(SocketAddressLegacy, 1);
  1216. if (path) {
  1217. UnixSocketAddress *q_unix;
  1218. addr->type = SOCKET_ADDRESS_LEGACY_KIND_UNIX;
  1219. q_unix = addr->u.q_unix.data = g_new0(UnixSocketAddress, 1);
  1220. q_unix->path = g_strdup(path);
  1221. } else if (host) {
  1222. addr->type = SOCKET_ADDRESS_LEGACY_KIND_INET;
  1223. addr->u.inet.data = g_new(InetSocketAddress, 1);
  1224. *addr->u.inet.data = (InetSocketAddress) {
  1225. .host = g_strdup(host),
  1226. .port = g_strdup(port),
  1227. .has_to = qemu_opt_get(opts, "to"),
  1228. .to = qemu_opt_get_number(opts, "to", 0),
  1229. .has_ipv4 = qemu_opt_get(opts, "ipv4"),
  1230. .ipv4 = qemu_opt_get_bool(opts, "ipv4", 0),
  1231. .has_ipv6 = qemu_opt_get(opts, "ipv6"),
  1232. .ipv6 = qemu_opt_get_bool(opts, "ipv6", 0),
  1233. };
  1234. } else if (fd) {
  1235. addr->type = SOCKET_ADDRESS_LEGACY_KIND_FD;
  1236. addr->u.fd.data = g_new(String, 1);
  1237. addr->u.fd.data->str = g_strdup(fd);
  1238. } else {
  1239. g_assert_not_reached();
  1240. }
  1241. sock->addr = addr;
  1242. }
  1243. static void
  1244. char_socket_get_addr(Object *obj, Visitor *v, const char *name,
  1245. void *opaque, Error **errp)
  1246. {
  1247. SocketChardev *s = SOCKET_CHARDEV(obj);
  1248. visit_type_SocketAddress(v, name, &s->addr, errp);
  1249. }
  1250. static bool
  1251. char_socket_get_connected(Object *obj, Error **errp)
  1252. {
  1253. SocketChardev *s = SOCKET_CHARDEV(obj);
  1254. return s->state == TCP_CHARDEV_STATE_CONNECTED;
  1255. }
  1256. static void char_socket_class_init(ObjectClass *oc, void *data)
  1257. {
  1258. ChardevClass *cc = CHARDEV_CLASS(oc);
  1259. cc->parse = qemu_chr_parse_socket;
  1260. cc->open = qmp_chardev_open_socket;
  1261. cc->chr_wait_connected = tcp_chr_wait_connected;
  1262. cc->chr_write = tcp_chr_write;
  1263. cc->chr_sync_read = tcp_chr_sync_read;
  1264. cc->chr_disconnect = tcp_chr_disconnect;
  1265. cc->get_msgfds = tcp_get_msgfds;
  1266. cc->set_msgfds = tcp_set_msgfds;
  1267. cc->chr_add_client = tcp_chr_add_client;
  1268. cc->chr_add_watch = tcp_chr_add_watch;
  1269. cc->chr_update_read_handler = tcp_chr_update_read_handler;
  1270. object_class_property_add(oc, "addr", "SocketAddress",
  1271. char_socket_get_addr, NULL,
  1272. NULL, NULL, &error_abort);
  1273. object_class_property_add_bool(oc, "connected", char_socket_get_connected,
  1274. NULL, &error_abort);
  1275. }
  1276. static const TypeInfo char_socket_type_info = {
  1277. .name = TYPE_CHARDEV_SOCKET,
  1278. .parent = TYPE_CHARDEV,
  1279. .instance_size = sizeof(SocketChardev),
  1280. .instance_finalize = char_socket_finalize,
  1281. .class_init = char_socket_class_init,
  1282. };
  1283. static void register_types(void)
  1284. {
  1285. type_register_static(&char_socket_type_info);
  1286. }
  1287. type_init(register_types);