|
|
1.1 ! root 1: /* ! 2: * Cisco router simulation platform. ! 3: * Copyright (c) 2006 Christophe Fillot ([email protected]) ! 4: * ! 5: * Hypervisor C2600 routines. ! 6: */ ! 7: ! 8: #include <stdio.h> ! 9: #include <stdlib.h> ! 10: #include <unistd.h> ! 11: #include <string.h> ! 12: #include <sys/types.h> ! 13: #include <sys/stat.h> ! 14: #include <sys/mman.h> ! 15: #include <signal.h> ! 16: #include <fcntl.h> ! 17: #include <errno.h> ! 18: #include <assert.h> ! 19: #include <stdarg.h> ! 20: #include <sys/ioctl.h> ! 21: #include <sys/types.h> ! 22: #include <sys/socket.h> ! 23: #include <arpa/inet.h> ! 24: #include <pthread.h> ! 25: ! 26: #include "cpu.h" ! 27: #include "vm.h" ! 28: #include "device.h" ! 29: #include "dev_c2600.h" ! 30: #include "dev_vtty.h" ! 31: #include "utils.h" ! 32: #include "net.h" ! 33: #include "atm.h" ! 34: #include "frame_relay.h" ! 35: #include "crc.h" ! 36: #include "net_io.h" ! 37: #include "net_io_bridge.h" ! 38: #ifdef GEN_ETH ! 39: #include "gen_eth.h" ! 40: #endif ! 41: #include "registry.h" ! 42: #include "hypervisor.h" ! 43: ! 44: /* Create a C2600 instance */ ! 45: static int cmd_create(hypervisor_conn_t *conn,int argc,char *argv[]) ! 46: { ! 47: c2600_t *router; ! 48: ! 49: if (!(router = c2600_create_instance(argv[0],atoi(argv[1])))) { ! 50: hypervisor_send_reply(conn,HSC_ERR_CREATE,1, ! 51: "unable to create C2600 instance '%s'", ! 52: argv[0]); ! 53: return(-1); ! 54: } ! 55: ! 56: router->vm->vtty_con_type = VTTY_TYPE_NONE; ! 57: router->vm->vtty_aux_type = VTTY_TYPE_NONE; ! 58: ! 59: vm_release(router->vm); ! 60: hypervisor_send_reply(conn,HSC_INFO_OK,1,"C2600 '%s' created",argv[0]); ! 61: return(0); ! 62: } ! 63: ! 64: /* Delete a C2600 instance */ ! 65: static int cmd_delete(hypervisor_conn_t *conn,int argc,char *argv[]) ! 66: { ! 67: int res; ! 68: ! 69: res = c2600_delete_instance(argv[0]); ! 70: ! 71: if (res == 1) { ! 72: hypervisor_send_reply(conn,HSC_INFO_OK,1,"C2600 '%s' deleted",argv[0]); ! 73: } else { ! 74: hypervisor_send_reply(conn,HSC_ERR_DELETE,1, ! 75: "unable to delete C2600 '%s'",argv[0]); ! 76: } ! 77: ! 78: return(res); ! 79: } ! 80: ! 81: /* Set the chassis type */ ! 82: static int cmd_set_chassis(hypervisor_conn_t *conn,int argc,char *argv[]) ! 83: { ! 84: vm_instance_t *vm; ! 85: ! 86: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 87: return(-1); ! 88: ! 89: if ((c2600_mainboard_set_type(VM_C2600(vm),argv[1])) == -1) { ! 90: vm_release(vm); ! 91: hypervisor_send_reply(conn,HSC_ERR_CREATE,1, ! 92: "unable to set Chassis type for router '%s'", ! 93: argv[0]); ! 94: return(-1); ! 95: } ! 96: ! 97: vm_release(vm); ! 98: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 99: return(0); ! 100: } ! 101: ! 102: /* Set the I/O mem size */ ! 103: static int cmd_set_iomem(hypervisor_conn_t *conn,int argc,char *argv[]) ! 104: { ! 105: vm_instance_t *vm; ! 106: ! 107: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 108: return(-1); ! 109: ! 110: VM_C2600(vm)->nm_iomem_size = 0x8000 | atoi(optarg); ! 111: ! 112: vm_release(vm); ! 113: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 114: return(0); ! 115: } ! 116: ! 117: /* Set the base MAC address for the chassis */ ! 118: static int cmd_set_mac_addr(hypervisor_conn_t *conn,int argc,char *argv[]) ! 119: { ! 120: vm_instance_t *vm; ! 121: ! 122: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 123: return(-1); ! 124: ! 125: if ((c2600_chassis_set_mac_addr(VM_C2600(vm),argv[1])) == -1) { ! 126: vm_release(vm); ! 127: hypervisor_send_reply(conn,HSC_ERR_CREATE,1, ! 128: "unable to set MAC address for router '%s'", ! 129: argv[0]); ! 130: return(-1); ! 131: } ! 132: ! 133: vm_release(vm); ! 134: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 135: return(0); ! 136: } ! 137: ! 138: /* Start a C2600 instance */ ! 139: static int cmd_start(hypervisor_conn_t *conn,int argc,char *argv[]) ! 140: { ! 141: vm_instance_t *vm; ! 142: c2600_t *router; ! 143: ! 144: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 145: return(-1); ! 146: ! 147: router = VM_C2600(vm); ! 148: ! 149: if (router->vm->vtty_con_type == VTTY_TYPE_NONE) { ! 150: hypervisor_send_reply(conn,HSC_INFO_MSG,0, ! 151: "Warning: no console port defined for " ! 152: "C2600 '%s'",argv[0]); ! 153: } ! 154: ! 155: if (c2600_init_instance(router) == -1) { ! 156: vm_release(vm); ! 157: hypervisor_send_reply(conn,HSC_ERR_START,1, ! 158: "unable to start instance '%s'", ! 159: argv[0]); ! 160: return(-1); ! 161: } ! 162: ! 163: vm_release(vm); ! 164: hypervisor_send_reply(conn,HSC_INFO_OK,1,"C2600 '%s' started",argv[0]); ! 165: return(0); ! 166: } ! 167: ! 168: /* Stop a C2600 instance */ ! 169: static int cmd_stop(hypervisor_conn_t *conn,int argc,char *argv[]) ! 170: { ! 171: vm_instance_t *vm; ! 172: c2600_t *router; ! 173: ! 174: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 175: return(-1); ! 176: ! 177: router = VM_C2600(vm); ! 178: ! 179: if (c2600_stop_instance(router) == -1) { ! 180: vm_release(vm); ! 181: hypervisor_send_reply(conn,HSC_ERR_STOP,1, ! 182: "unable to stop instance '%s'", ! 183: argv[0]); ! 184: return(-1); ! 185: } ! 186: ! 187: vm_release(vm); ! 188: hypervisor_send_reply(conn,HSC_INFO_OK,1,"C2600 '%s' stopped",argv[0]); ! 189: return(0); ! 190: } ! 191: ! 192: /* Show NM bindings */ ! 193: static int cmd_nm_bindings(hypervisor_conn_t *conn,int argc,char *argv[]) ! 194: { ! 195: vm_instance_t *vm; ! 196: c2600_t *router; ! 197: char *nm_type; ! 198: int i; ! 199: ! 200: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 201: return(-1); ! 202: ! 203: router = VM_C2600(vm); ! 204: ! 205: for(i=0;i<C2600_MAX_NM_BAYS;i++) { ! 206: nm_type = c2600_nm_get_type(router,i); ! 207: if (nm_type) ! 208: hypervisor_send_reply(conn,HSC_INFO_MSG,0,"%u: %s",i,nm_type); ! 209: } ! 210: ! 211: vm_release(vm); ! 212: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 213: return(0); ! 214: } ! 215: ! 216: /* Show NM NIO bindings */ ! 217: static int cmd_nm_nio_bindings(hypervisor_conn_t *conn,int argc,char *argv[]) ! 218: { ! 219: struct c2600_nio_binding *nb; ! 220: struct c2600_nm_bay *bay; ! 221: vm_instance_t *vm; ! 222: c2600_t *router; ! 223: u_int nm_bay; ! 224: ! 225: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 226: return(-1); ! 227: ! 228: router = VM_C2600(vm); ! 229: nm_bay = atoi(argv[1]); ! 230: ! 231: if (!(bay = c2600_nm_get_info(router,nm_bay))) { ! 232: vm_release(vm); ! 233: hypervisor_send_reply(conn,HSC_ERR_UNK_OBJ,1,"Invalid slot %u",nm_bay); ! 234: return(-1); ! 235: } ! 236: ! 237: for(nb=bay->nio_list;nb;nb=nb->next) ! 238: hypervisor_send_reply(conn,HSC_INFO_MSG,0,"%u: %s", ! 239: nb->port_id,nb->nio->name); ! 240: ! 241: vm_release(vm); ! 242: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 243: return(0); ! 244: } ! 245: ! 246: /* Add a NM binding for the specified slot */ ! 247: static int cmd_add_nm_binding(hypervisor_conn_t *conn,int argc,char *argv[]) ! 248: { ! 249: vm_instance_t *vm; ! 250: c2600_t *router; ! 251: u_int nm_bay; ! 252: ! 253: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 254: return(-1); ! 255: ! 256: router = VM_C2600(vm); ! 257: nm_bay = atoi(argv[1]); ! 258: ! 259: if (c2600_nm_add_binding(router,argv[2],nm_bay) == -1) { ! 260: vm_release(vm); ! 261: hypervisor_send_reply(conn,HSC_ERR_BINDING,1, ! 262: "C2600 %s: unable to add NM binding for slot %u", ! 263: argv[0],nm_bay); ! 264: return(-1); ! 265: } ! 266: ! 267: vm_release(vm); ! 268: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 269: return(0); ! 270: } ! 271: ! 272: /* Remove a NM binding for the specified slot */ ! 273: static int cmd_remove_nm_binding(hypervisor_conn_t *conn,int argc,char *argv[]) ! 274: { ! 275: vm_instance_t *vm; ! 276: c2600_t *router; ! 277: u_int nm_bay; ! 278: ! 279: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 280: return(-1); ! 281: ! 282: router = VM_C2600(vm); ! 283: nm_bay = atoi(argv[1]); ! 284: ! 285: if (c2600_nm_remove_binding(router,nm_bay) == -1) { ! 286: vm_release(vm); ! 287: hypervisor_send_reply(conn,HSC_ERR_BINDING,1, ! 288: "C2600 %s: unable to remove NM binding for " ! 289: "slot %u",argv[0],nm_bay); ! 290: return(-1); ! 291: } ! 292: ! 293: vm_release(vm); ! 294: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 295: return(0); ! 296: } ! 297: ! 298: /* Add a NIO binding to the specified slot/port */ ! 299: static int cmd_add_nio_binding(hypervisor_conn_t *conn,int argc,char *argv[]) ! 300: { ! 301: u_int nm_bay,port_id; ! 302: vm_instance_t *vm; ! 303: c2600_t *router; ! 304: ! 305: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 306: return(-1); ! 307: ! 308: router = VM_C2600(vm); ! 309: ! 310: nm_bay = atoi(argv[1]); ! 311: port_id = atoi(argv[2]); ! 312: ! 313: if (c2600_nm_add_nio_binding(router,nm_bay,port_id,argv[3]) == -1) { ! 314: vm_release(vm); ! 315: hypervisor_send_reply(conn,HSC_ERR_BINDING,1, ! 316: "C2600 %s: unable to add NIO binding for " ! 317: "interface %u/%u",argv[0],nm_bay,port_id); ! 318: return(-1); ! 319: } ! 320: ! 321: vm_release(vm); ! 322: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 323: return(0); ! 324: } ! 325: ! 326: /* Remove a NIO binding from the specified slot/port */ ! 327: static int cmd_remove_nio_binding(hypervisor_conn_t *conn, ! 328: int argc,char *argv[]) ! 329: { ! 330: u_int nm_bay,port_id; ! 331: vm_instance_t *vm; ! 332: c2600_t *router; ! 333: ! 334: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 335: return(-1); ! 336: ! 337: router = VM_C2600(vm); ! 338: ! 339: nm_bay = atoi(argv[1]); ! 340: port_id = atoi(argv[2]); ! 341: ! 342: if (c2600_nm_remove_nio_binding(router,nm_bay,port_id) == -1) { ! 343: vm_release(vm); ! 344: hypervisor_send_reply(conn,HSC_ERR_BINDING,1, ! 345: "C2600 %s: unable to remove NIO binding for " ! 346: "interface %u/%u",argv[0],nm_bay,port_id); ! 347: return(-1); ! 348: } ! 349: ! 350: vm_release(vm); ! 351: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 352: return(0); ! 353: } ! 354: ! 355: /* Enable NIO of the specified slot/port */ ! 356: static int cmd_nm_enable_nio(hypervisor_conn_t *conn,int argc,char *argv[]) ! 357: { ! 358: u_int nm_bay,port_id; ! 359: vm_instance_t *vm; ! 360: c2600_t *router; ! 361: ! 362: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 363: return(-1); ! 364: ! 365: router = VM_C2600(vm); ! 366: ! 367: nm_bay = atoi(argv[1]); ! 368: port_id = atoi(argv[2]); ! 369: ! 370: if (c2600_nm_enable_nio(router,nm_bay,port_id) == -1) { ! 371: vm_release(vm); ! 372: hypervisor_send_reply(conn,HSC_ERR_BINDING,1, ! 373: "C2600 %s: unable to enable NIO for " ! 374: "interface %u/%u",argv[0],nm_bay,port_id); ! 375: return(-1); ! 376: } ! 377: ! 378: vm_release(vm); ! 379: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 380: return(0); ! 381: } ! 382: ! 383: /* Disable NIO of the specified slot/port */ ! 384: static int cmd_nm_disable_nio(hypervisor_conn_t *conn,int argc,char *argv[]) ! 385: { ! 386: u_int nm_bay,port_id; ! 387: vm_instance_t *vm; ! 388: c2600_t *router; ! 389: ! 390: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 391: return(-1); ! 392: ! 393: router = VM_C2600(vm); ! 394: ! 395: nm_bay = atoi(argv[1]); ! 396: port_id = atoi(argv[2]); ! 397: ! 398: if (c2600_nm_disable_nio(router,nm_bay,port_id) == -1) { ! 399: vm_release(vm); ! 400: hypervisor_send_reply(conn,HSC_ERR_BINDING,1, ! 401: "C2600 %s: unable to unset NIO for " ! 402: "interface %u/%u", ! 403: argv[0],nm_bay,port_id); ! 404: return(-1); ! 405: } ! 406: ! 407: vm_release(vm); ! 408: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 409: return(0); ! 410: } ! 411: ! 412: /* Show C2600 hardware */ ! 413: static int cmd_show_hardware(hypervisor_conn_t *conn,int argc,char *argv[]) ! 414: { ! 415: vm_instance_t *vm; ! 416: c2600_t *router; ! 417: ! 418: if (!(vm = hypervisor_find_vm(conn,argv[0],VM_TYPE_C2600))) ! 419: return(-1); ! 420: ! 421: router = VM_C2600(vm); ! 422: c2600_show_hardware(router); ! 423: ! 424: vm_release(vm); ! 425: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 426: return(0); ! 427: } ! 428: ! 429: /* Show info about C2600 object */ ! 430: static void cmd_show_c2600_list(registry_entry_t *entry,void *opt,int *err) ! 431: { ! 432: hypervisor_conn_t *conn = opt; ! 433: vm_instance_t *vm = entry->data; ! 434: ! 435: if (vm->type == VM_TYPE_C2600) ! 436: hypervisor_send_reply(conn,HSC_INFO_MSG,0,"%s",entry->name); ! 437: } ! 438: ! 439: /* C2600 List */ ! 440: static int cmd_c2600_list(hypervisor_conn_t *conn,int argc,char *argv[]) ! 441: { ! 442: int err = 0; ! 443: registry_foreach_type(OBJ_TYPE_VM,cmd_show_c2600_list,conn,&err); ! 444: hypervisor_send_reply(conn,HSC_INFO_OK,1,"OK"); ! 445: return(0); ! 446: } ! 447: ! 448: /* C2600 commands */ ! 449: static hypervisor_cmd_t c2600_cmd_array[] = { ! 450: { "create", 2, 2, cmd_create, NULL }, ! 451: { "delete", 1, 1, cmd_delete, NULL }, ! 452: { "set_chassis", 2, 2, cmd_set_chassis, NULL }, ! 453: { "set_iomem", 2, 2, cmd_set_iomem, NULL }, ! 454: { "set_mac_addr", 2, 2, cmd_set_mac_addr, NULL }, ! 455: { "start", 1, 1, cmd_start, NULL }, ! 456: { "stop", 1, 1, cmd_stop, NULL }, ! 457: { "nm_bindings", 1, 1, cmd_nm_bindings, NULL }, ! 458: { "nm_nio_bindings", 2, 2, cmd_nm_nio_bindings, NULL }, ! 459: { "add_nm_binding", 3, 3, cmd_add_nm_binding, NULL }, ! 460: { "remove_nm_binding", 2, 2, cmd_remove_nm_binding, NULL }, ! 461: { "add_nio_binding", 4, 4, cmd_add_nio_binding, NULL }, ! 462: { "remove_nio_binding", 3, 3, cmd_remove_nio_binding, NULL }, ! 463: { "nm_enable_nio", 3, 3, cmd_nm_enable_nio, NULL }, ! 464: { "nm_disable_nio", 3, 3, cmd_nm_disable_nio, NULL }, ! 465: { "show_hardware", 1, 1, cmd_show_hardware, NULL }, ! 466: { "list", 0, 0, cmd_c2600_list, NULL }, ! 467: { NULL, -1, -1, NULL, NULL }, ! 468: }; ! 469: ! 470: /* Hypervisor C2600 initialization */ ! 471: int hypervisor_c2600_init(void) ! 472: { ! 473: hypervisor_module_t *module; ! 474: ! 475: module = hypervisor_register_module("c2600"); ! 476: assert(module != NULL); ! 477: ! 478: hypervisor_register_cmd_array(module,c2600_cmd_array); ! 479: return(0); ! 480: }
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.