/* * hci.c * * Created by Matthias Ringwald on 4/29/09. * */ #include #include #include #include #include "hci.h" // calculate combined ogf/ocf value #define OPCODE(ogf, ocf) (ocf | ogf << 10) hci_cmd_t hci_inquiry = { OPCODE(0x01, 0x01), "311" // LAP, Inquiry length, Num_responses }; hci_cmd_t hci_reset = { OPCODE(0x03, 0x03), "" }; static hci_transport_t *hci_transport; void hexdump(uint8_t *data, int size){ int i; for (i=0; isend_cmd_packet(buffer, size); } void hci_run(){ while (1) { // construct file descriptor set to wait for // select // for each ready file in FD - call handle_data sleep(1); } } void hci_create_cmd_packet(uint8_t *buffer, uint8_t *cmd_len, hci_cmd_t *cmd, ...){ buffer[0] = cmd->opcode & 0xff; buffer[1] = cmd->opcode >> 8; int pos = 3; va_list argptr; va_start(argptr, cmd); const char *format = cmd->format; uint16_t word; uint32_t longword; uint8_t * bt_addr; while (*format) { switch(*format) { case '1': // 8 bit value case '2': // 16 bit value case 'H': // hci_handle word = va_arg(argptr, int); // minimal va_arg is int: 2 bytes on 8+16 bit CPUs buffer[pos++] = word & 0xff; if (*format == '2') { buffer[pos++] = word >> 8; } else if (*format == 'H') { // TODO } break; case '3': case '4': longword = va_arg(argptr, uint32_t); // longword = va_arg(argptr, int); buffer[pos++] = longword; buffer[pos++] = longword >> 8; buffer[pos++] = longword >> 16; if (*format == '4'){ buffer[pos++] = longword >> 24; } break; case 'B': // bt-addr bt_addr = va_arg(argptr, uint8_t *); memcpy( &buffer[pos], bt_addr, 6); pos += 6; break; default: break; } format++; }; va_end(argptr); buffer[2] = pos - 3; *cmd_len = pos; }