WELCOME_PACKET create_queue() {//Create a new queue in the queue manager returning its ticket //TODO:refactor WELCOME_PACKET outcome; QUEUE_TICKET ticket = 0; outcome.result = set_result(SUCCESS,""); PRIORITY_QUEUE* pQueue = NULL; int indexFound = find_open_slot(); if(indexFound == -1) outcome.result = set_result(QUEUE_CANNOT_BE_CREATED, "Exceeded maximum number of queues"); if(outcome.result.code == SUCCESS) //Using outcome's error flag to avoid nested if-else {//Create a ticket ticket = create_ticket(indexFound); if(ticket == 0) outcome.result = set_result(QUEUE_CANNOT_BE_CREATED, "Ticket creation failed"); } if(outcome.result.code == SUCCESS) {//Malloc new queue pQueue = (PRIORITY_QUEUE*) malloc(sizeof(PRIORITY_QUEUE)); if(pQueue == NULL) outcome.result = set_result(OUT_OF_MEMORY, "Failed to allocate memory"); } if(outcome.result.code == SUCCESS) {//Initialize new queue pQueue->ticket = ticket; pQueue->size = 0; pQueue->head = NULL; pQueue->tail = NULL; queue_guard.queues[indexFound] = pQueue; //Give queue manager the new queue queue_guard.size++; //Increment queue manager's size } outcome.ticket = ticket; return outcome; }
int auto_assign_slot(struct wiimoteglue_state* state, struct wii_device *dev) { if (state->num_slots > 0) { struct virtual_controller *slot = find_open_slot(state,dev->type); add_device_to_slot(state,dev,slot); } else { add_device_to_slot(state,dev,&state->slots[0]); /*If the user has no virtual gamepads, *they likely want devices to automatically *go to the keyboardmouse */ } if (dev->slot == NULL) { if (dev->type == BALANCE) { printf("Balance board detected, but there are no open slots\n"); } else { printf("Controller detected, but there are no open slots\n"); } close_wii_device(state,dev); return 0; } if (dev->type == BALANCE) { printf("Balance Board added to slot %s\n",dev->slot->slot_name); } else { printf("Controller added to slot %s\n",dev->slot->slot_name); } return 0; }
/** * Processes a new incoming ANNOUNCE */ void handle_announce(union sockaddr_u *src, unsigned char *packet, unsigned packetlen, struct timeval rxtime) { struct uftp_h *header; struct announce_h *announce; uint32_t *addrlist; int addrlen, rval; struct group_list_t *group; time_t t; struct tm *start_time; char privname[INET6_ADDRSTRLEN], srcname[INET6_ADDRSTRLEN]; char srcfqdn[DESTNAME_LEN]; header = (struct uftp_h *)packet; announce = (struct announce_h *)(packet + sizeof(struct uftp_h)); addrlist = (uint32_t *)((unsigned char *)announce + (announce->hlen * 4)); addrlen = (packetlen - sizeof(struct uftp_h) - (announce->hlen * 4)) / 4; if ((packetlen < sizeof(struct uftp_h) + (announce->hlen * 4U)) || ((announce->hlen * 4U) < sizeof(struct announce_h))) { log1(ntohl(header->group_id), header->group_inst, 0, "Rejecting ANNOUNCE from %08X: invalid message size", ntohl(header->src_id)); return; } if ((addrlen != 0) && (!uid_in_list(addrlist, addrlen))) { log1(ntohl(header->group_id), header->group_inst, 0, "Name not in host list"); return; } if ((group = find_open_slot()) == NULL ) { log0(ntohl(header->group_id), header->group_inst, 0, "Error: maximum number of incoming files exceeded: %d\n", MAXLIST); return; } t = time(NULL); start_time = localtime(&t); snprintf(group->start_date, sizeof(group->start_date), "%04d%02d%02d", start_time->tm_year + 1900, start_time->tm_mon + 1, start_time->tm_mday); snprintf(group->start_time, sizeof(group->start_time), "%02d%02d%02d", start_time->tm_hour, start_time->tm_min, start_time->tm_sec); if (!read_announce(group, packet, src, rxtime, packetlen)) { return; } if ((rval = getnameinfo((struct sockaddr *)src, family_len(*src), srcname, sizeof(srcname), NULL, 0, NI_NUMERICHOST)) != 0) { glog1(group, "getnameinfo failed: %s", gai_strerror(rval)); } if (!noname) { if ((rval = getnameinfo((struct sockaddr *)src, family_len(*src), srcfqdn, sizeof(srcfqdn), NULL, 0, 0)) != 0) { glog1(group, "getnameinfo failed: %s", gai_strerror(rval)); } } else { strncpy(srcfqdn, srcname, sizeof(srcfqdn) - 1); } if ((rval = getnameinfo((struct sockaddr *)&group->multi, family_len(group->multi), privname, sizeof(privname), NULL, 0, NI_NUMERICHOST)) != 0) { glog1(group, "getnameinfo failed: %s", gai_strerror(rval)); } glog2(group, "Received request from %08X at %s (%s)", ntohl(group->src_id), srcfqdn, srcname); glog2(group, "Using private multicast address %s", privname); glog3(group, "grtt = %.6f", group->grtt); glog3(group, "send time: %d.%06d", group->last_server_ts.tv_sec, group->last_server_ts.tv_usec); glog3(group, "receive time: %d.%06d", group->last_server_rx_ts.tv_sec, group->last_server_rx_ts.tv_usec); if (status_file) { fprintf(status_file, "CONNECT;%04d/%02d/%02d-%02d:%02d:%02d;%08X;%08X;%s;%s\n", start_time->tm_year + 1900, start_time->tm_mon + 1, start_time->tm_mday, start_time->tm_hour, start_time->tm_min, start_time->tm_sec, ntohl(group->src_id), group->group_id, srcname, srcfqdn); fflush(status_file); } if (group->restart) { if (group->sync_mode) { glog1(group, "Sync mode and restart mode incompatible"); send_abort(group, "Sync mode and restart mode incompatible"); return; } } if (!addr_blank(&group->multi)) { if (server_count > 0) { if (!is_multicast(&group->multi, 1)) { glog1(group, "Invalid source specific multicast address: %s", privname); send_abort(group, "Invalid source specific multicast address"); return; } if (!other_mcast_users(group)) { if (!multicast_join(listener, group->group_id, &group->multi, m_interface, interface_count, server_keys, server_count)) { send_abort(group, "Error joining multicast group"); return; } if (has_proxy) { if (!multicast_join(listener,group->group_id, &group->multi, m_interface, interface_count, &proxy_info, 1)) { send_abort(group, "Error joining multicast group"); return; } } } } else { if (!is_multicast(&group->multi, 0)) { glog1(group, "Invalid multicast address: %s", privname); send_abort(group, "Invalid multicast address"); return; } if (!other_mcast_users(group)) { if (!multicast_join(listener, group->group_id, &group->multi, m_interface, interface_count, NULL, 0)) { send_abort(group, "Error joining multicast group"); return; } } } group->multi_join = 1; } send_register(group); }