videohubctrl can be used to control Blackmagic Design Videohub SDI router device over the network.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

display.c 6.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. /*
  2. * === Display functions ===
  3. *
  4. * Blackmagic Design Videohub control application
  5. * Copyright (C) 2014 Unix Solutions Ltd.
  6. * Written by Georgi Chorbadzhiyski
  7. *
  8. * Released under MIT license.
  9. * See LICENSE-MIT.txt for license terms.
  10. *
  11. */
  12. #include <stdio.h>
  13. #include <string.h>
  14. #include "data.h"
  15. #include "cmd.h"
  16. #include "util.h"
  17. #include "display.h"
  18. static void printf_line(int len) {
  19. int i;
  20. printf(" ");
  21. for (i = 0; i < len; i++)
  22. printf("-");
  23. printf("\n");
  24. }
  25. static char format_status(enum port_status status) {
  26. switch (status) {
  27. case S_UNKNOWN: return ' ';
  28. case S_BNC : return 'B';
  29. case S_OPTICAL: return 'o';
  30. case S_NONE : return 'x';
  31. case S_RS422 : return '4'; // For serial ports
  32. }
  33. return '?';
  34. }
  35. void print_device_info(struct videohub_data *d) {
  36. int len = 59;
  37. printf("Device info\n");
  38. printf_line(len);
  39. printf(" | %-26s | %-26s |\n", "Device address", d->dev_host);
  40. printf(" | %-26s | %-26s |\n", "Device port", d->dev_port);
  41. printf(" | %-26s | %-26s |\n", "Model name", d->device.model_name);
  42. printf(" | %-26s | %-26s |\n", "Unique ID", d->device.unique_id);
  43. printf(" | %-26s | %-26s |\n", "Protocol", d->device.protocol_ver);
  44. printf(" | %-26s | %-26u |\n", "Video inputs", d->inputs.num);
  45. printf(" | %-26s | %-26u |\n", "Video outputs", d->outputs.num);
  46. if (d->serial.num)
  47. printf(" | %-26s | %-26u |\n", "Serial ports", d->serial.num);
  48. if (d->device.num_video_processing_units)
  49. printf(" | %-26s | %-26u |\n", "Video processing units", d->device.num_video_processing_units);
  50. if (d->mon_outputs.num)
  51. printf(" | %-26s | %-26u |\n", "Video monitoring outputs", d->mon_outputs.num);
  52. printf_line(len);
  53. printf("\n");
  54. }
  55. void print_device_video_inputs(struct videohub_data *d) {
  56. unsigned int i, r, len = 68;
  57. if (!d->inputs.num)
  58. return;
  59. printf("Video inputs\n");
  60. printf_line(len);
  61. printf(" | ## | %-24s | n | %-24s | s |\n", "Video input name", "Routed to output");
  62. printf_line(len);
  63. for(i = 0; i < d->inputs.num; i++) {
  64. unsigned int num_outputs = 0, routed_to = 0;
  65. for(r = 0; r < d->outputs.num; r++) {
  66. if (d->outputs.port[r].routed_to == i) {
  67. num_outputs++;
  68. if (num_outputs == 1)
  69. routed_to = r; // The first output
  70. }
  71. }
  72. printf(" | %2d | %-24s | %d | ", i + 1, d->inputs.port[i].name,
  73. num_outputs);
  74. if (num_outputs == 0) {
  75. printf("%-24s | %c |\n", "-", format_status(d->inputs.port[i].status));
  76. } else {
  77. printf("%-24s | %c |\n",
  78. routed_to == NO_PORT ? "" : d->outputs.port[routed_to].name,
  79. format_status(d->inputs.port[i].status)
  80. );
  81. bool first_skipped = false;
  82. for(r = 0; r < d->outputs.num; r++) {
  83. if (d->outputs.port[r].routed_to == i) {
  84. if (!first_skipped) {
  85. first_skipped = true;
  86. continue;
  87. }
  88. printf(" | %2s | %-24s | %s | %-24s | %c |\n",
  89. " ", " ", " ", d->outputs.port[r].name, ' ');
  90. }
  91. }
  92. }
  93. }
  94. printf_line(len);
  95. printf("\n");
  96. }
  97. static char port_lock_symbol(enum port_lock p) {
  98. switch(p) {
  99. case PORT_UNLOCKED : return ' ';
  100. case PORT_LOCKED : return 'O';
  101. case PORT_LOCKED_OTHER: return 'L';
  102. }
  103. return '?';
  104. }
  105. void print_device_video_outputs(struct videohub_data *d) {
  106. unsigned int i, len = 68;
  107. if (!d->outputs.num)
  108. return;
  109. printf("Video outputs\n");
  110. printf_line(len);
  111. printf(" | ## | x | %-24s | %-24s | s |\n", "Video output name", "Connected video input");
  112. printf_line(len);
  113. for(i = 0; i < d->outputs.num; i++) {
  114. printf(" | %2d | %c | %-24s | %-24s | %c |\n",
  115. i + 1,
  116. port_lock_symbol(d->outputs.port[i].lock),
  117. d->outputs.port[i].name,
  118. d->outputs.port[i].routed_to == NO_PORT ? "" : d->inputs.port[d->outputs.port[i].routed_to].name,
  119. format_status(d->outputs.port[i].status)
  120. );
  121. }
  122. printf_line(len);
  123. printf("\n");
  124. }
  125. void print_device_monitoring_outputs(struct videohub_data *d) {
  126. unsigned int i, len = 64;
  127. if (!d->mon_outputs.num)
  128. return;
  129. printf("Monitoring outputs\n");
  130. printf_line(len);
  131. printf(" | ## | x | %-24s | %-24s |\n", "Monitoring output name", "Connected video input");
  132. printf_line(len);
  133. for(i = 0; i < d->mon_outputs.num; i++) {
  134. printf(" | %2d | %c | %-24s | %-24s |\n",
  135. i + 1,
  136. port_lock_symbol(d->mon_outputs.port[i].lock),
  137. d->mon_outputs.port[i].name,
  138. d->mon_outputs.port[i].routed_to == NO_PORT ? "" : d->inputs.port[d->mon_outputs.port[i].routed_to].name
  139. );
  140. }
  141. printf_line(len);
  142. printf("\n");
  143. }
  144. static char *dir2opt(enum serial_dir dir) {
  145. switch (dir) {
  146. case DIR_CONTROL: return "in";
  147. case DIR_SLAVE : return "out";
  148. case DIR_AUTO : return "auto";
  149. }
  150. return "auto";
  151. }
  152. void print_device_serial_ports(struct videohub_data *d) {
  153. unsigned int i, len = 63;
  154. if (!d->serial.num)
  155. return;
  156. printf("Serial ports\n");
  157. printf_line(len);
  158. printf(" | ## | x | Dir | %-18s | %-18s | s |\n", "Serial port", "Connected serial");
  159. printf_line(len);
  160. for(i = 0; i < d->serial.num; i++) {
  161. printf(" | %2d | %c | %4s | %-18s | %-18s | %c |\n",
  162. i + 1,
  163. port_lock_symbol(d->serial.port[i].lock),
  164. dir2opt(d->serial.port[i].direction),
  165. d->serial.port[i].name,
  166. d->serial.port[i].routed_to == NO_PORT ? "" : d->serial.port[d->serial.port[i].routed_to].name,
  167. format_status(d->serial.port[i].status)
  168. );
  169. }
  170. printf_line(len);
  171. printf("\n");
  172. }
  173. static void __print_opt(struct videohub_data *d, enum vcmd vcmd) {
  174. unsigned int i, last = 0;
  175. struct videohub_commands *v = &videohub_commands[vcmd];
  176. struct port_set *s_port = !v->ports1 ? NULL : (void *)d + v->ports1;
  177. const char *p = v->opt_prefix;
  178. for(i = 0; i < s_port->num; i++) {
  179. switch (v->type) {
  180. case PARSE_LABEL:
  181. printf(" --%s-name %2d \"%s\" \\\n", p, i + 1, s_port->port[i].name);
  182. break;
  183. case PARSE_ROUTE:
  184. if (s_port->port[i].routed_to == NO_PORT)
  185. continue;
  186. printf(" --%s-input %2d %2d \\\n", p, i + 1, s_port->port[i].routed_to + 1);
  187. break;
  188. case PARSE_LOCK:
  189. last = i + 1 < s_port->num;
  190. if (s_port->port[i].lock != PORT_UNLOCKED) {
  191. printf(" --%s-unlock %2d --%s-lock %2d%s\n",
  192. p, i + 1, p, i + 1, last ? " \\" : "");
  193. } else {
  194. printf(" --%s-unlock %2d%s\n", p, i + 1, last ? " \\" : "");
  195. }
  196. break;
  197. case PARSE_DIR:
  198. printf(" --%s-dir %2d %s \\\n", p, i + 1, dir2opt(s_port->port[i].direction));
  199. break;
  200. default: break;
  201. }
  202. }
  203. }
  204. void print_device_backup(struct videohub_data *d) {
  205. unsigned int i;
  206. printf("videohubctrl \\\n");
  207. for (i = 0; i < NUM_COMMANDS; i++) {
  208. if (videohub_commands[i].type == PARSE_LABEL)
  209. __print_opt(d, videohub_commands[i].cmd);
  210. }
  211. for (i = 0; i < NUM_COMMANDS; i++) {
  212. if (videohub_commands[i].type == PARSE_ROUTE)
  213. __print_opt(d, videohub_commands[i].cmd);
  214. }
  215. for (i = 0; i < NUM_COMMANDS; i++) {
  216. if (videohub_commands[i].type == PARSE_DIR)
  217. __print_opt(d, videohub_commands[i].cmd);
  218. }
  219. for (i = 0; i < NUM_COMMANDS; i++) {
  220. if (videohub_commands[i].type == PARSE_LOCK)
  221. __print_opt(d, videohub_commands[i].cmd);
  222. }
  223. printf("\n");
  224. }