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.8KB

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