⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hci.c

📁 Bluezan implementation of the Bluetooth&#8482 wireless standards specifications for Linux. The code
💻 C
📖 第 1 页 / 共 4 页
字号:
static inline void read_class_of_dev_dump(int level, struct frame *frm){	read_class_of_dev_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x class 0x%2.2x%2.2x%2.2x\n", rp->status,		rp->dev_class[2], rp->dev_class[1], rp->dev_class[0]);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_voice_setting_dump(int level, struct frame *frm){	read_voice_setting_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x voice setting 0x%4.4x\n",		rp->status, btohs(rp->voice_setting));	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_current_iac_lap_dump(int level, struct frame *frm){	read_current_iac_lap_rp *rp = frm->ptr;	int i;	for (i = 0; i < rp->num_current_iac; i++) {		p_indent(level, frm);		printf("IAC 0x%2.2x%2.2x%2.2x", rp->lap[i][2], rp->lap[i][1], rp->lap[i][0]);		if (rp->lap[i][2] == 0x9e && rp->lap[i][1] == 0x8b) {			switch (rp->lap[i][0]) {			case 0x00:				printf(" (Limited Inquiry Access Code)");				break;			case 0x33:				printf(" (General Inquiry Access Code)");				break;			}		}		printf("\n");	}}static inline void read_scan_enable_dump(int level, struct frame *frm){	uint8_t status = get_u8(frm);	uint8_t enable = get_u8(frm);	p_indent(level, frm);	printf("status 0x%2.2x enable %d\n", status, enable);	if (status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(status));	}}static inline void read_page_timeout_dump(int level, struct frame *frm){	read_page_timeout_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x timeout %d\n", rp->status, btohs(rp->timeout));	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_page_activity_dump(int level, struct frame *frm){	read_page_activity_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x interval %d window %d\n",		rp->status, btohs(rp->interval), btohs(rp->window));	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_inquiry_mode_dump(int level, struct frame *frm){	read_inquiry_mode_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x mode %d\n", rp->status, rp->mode);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_link_supervision_timeout_dump(int level, struct frame *frm){	read_link_supervision_timeout_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x handle %d timeout %d\n",		rp->status, btohs(rp->handle), btohs(rp->link_sup_to));	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_transmit_power_level_dump(int level, struct frame *frm){	read_transmit_power_level_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x handle %d level %d\n",		rp->status, btohs(rp->handle), rp->level);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_local_version_dump(int level, struct frame *frm){	read_local_version_rp *rp = frm->ptr;	uint16_t manufacturer = btohs(rp->manufacturer);	p_indent(level, frm);	printf("status 0x%2.2x\n", rp->status);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	} else {		p_indent(level, frm);		printf("HCI Version: %s (0x%x) HCI Revision: 0x%x\n",			hci_vertostr(rp->hci_ver), rp->hci_ver,			btohs(rp->hci_rev));		p_indent(level, frm);		printf("LMP Version: %s (0x%x) LMP Subversion: 0x%x\n",			lmp_vertostr(rp->lmp_ver), rp->lmp_ver,			btohs(rp->lmp_subver));		p_indent(level, frm);		printf("Manufacturer: %s (%d)\n",			bt_compidtostr(manufacturer), manufacturer);	}}static inline void read_local_commands_dump(int level, struct frame *frm){	read_local_commands_rp *rp = frm->ptr;	int i, max = 0;	p_indent(level, frm);	printf("status 0x%2.2x\n", rp->status);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	} else {		for (i = 0; i < 64; i++)			if (rp->commands[i])				max = i + 1;		p_indent(level, frm);		printf("Commands: ");		for (i = 0; i < (max > 32 ? 32 : max); i++)			printf("%2.2x", rp->commands[i]);		printf("\n");		if (max > 32) {			p_indent(level, frm);			printf("          ");			for (i = 32; i < max; i++)				printf("%2.2x", rp->commands[i]);			printf("\n");		}	}}static inline void read_local_features_dump(int level, struct frame *frm){	read_local_features_rp *rp = frm->ptr;	int i;	p_indent(level, frm);	printf("status 0x%2.2x\n", rp->status);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	} else {		p_indent(level, frm);		printf("Features:");		for (i = 0; i < 8; i++)			printf(" 0x%2.2x", rp->features[i]);		printf("\n");	}}static inline void read_local_ext_features_dump(int level, struct frame *frm){	read_local_ext_features_rp *rp = frm->ptr;	int i;	p_indent(level, frm);	printf("status 0x%2.2x page %d max %d\n",		rp->status, rp->page_num, rp->max_page_num);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	} else {		p_indent(level, frm);		printf("Features:");		for (i = 0; i < 8; i++)			 printf(" 0x%2.2x", rp->features[i]);		printf("\n");	}}static inline void read_buffer_size_dump(int level, struct frame *frm){	read_buffer_size_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x\n", rp->status);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	} else {		p_indent(level, frm);		printf("ACL MTU %d:%d SCO MTU %d:%d\n",			btohs(rp->acl_mtu), btohs(rp->acl_max_pkt),			rp->sco_mtu, btohs(rp->sco_max_pkt));	}}static inline void read_link_quality_dump(int level, struct frame *frm){	read_link_quality_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x handle %d lq %d\n",		rp->status, btohs(rp->handle), rp->link_quality);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_rssi_dump(int level, struct frame *frm){	read_rssi_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x handle %d rssi %d\n",		rp->status, btohs(rp->handle), rp->rssi);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void read_afh_map_dump(int level, struct frame *frm){	read_afh_map_rp *rp = frm->ptr;	int i;	p_indent(level, frm);	printf("status 0x%2.2x handle %d mode %d\n",		rp->status, btohs(rp->handle), rp->mode);	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	} else {		p_indent(level, frm);		printf("AFH map: 0x");		for (i = 0; i < 10; i++)			printf("%2.2x", rp->map[i]);		printf("\n");	}}static inline void read_clock_dump(int level, struct frame *frm){	read_clock_rp *rp = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x handle %d clock 0x%4.4x accuracy %d\n",		rp->status, btohs(rp->handle),		btohl(rp->clock), btohs(rp->accuracy));	if (rp->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(rp->status));	}}static inline void cmd_complete_dump(int level, struct frame *frm){	evt_cmd_complete *evt = frm->ptr;	uint16_t opcode = btohs(evt->opcode);	uint16_t ogf = cmd_opcode_ogf(opcode);	uint16_t ocf = cmd_opcode_ocf(opcode);	p_indent(level, frm);	printf("%s (0x%2.2x|0x%4.4x) ncmd %d\n",		opcode2str(opcode), ogf, ocf, evt->ncmd);	frm->ptr += EVT_CMD_COMPLETE_SIZE;	frm->len -= EVT_CMD_COMPLETE_SIZE;	switch (ogf) {	case OGF_LINK_CTL:		switch (ocf) {		case OCF_INQUIRY_CANCEL:		case OCF_PERIODIC_INQUIRY:		case OCF_EXIT_PERIODIC_INQUIRY:			status_response_dump(level, frm);			return;		case OCF_CREATE_CONN_CANCEL:		case OCF_REMOTE_NAME_REQ_CANCEL:		case OCF_PIN_CODE_REPLY:		case OCF_LINK_KEY_REPLY:		case OCF_PIN_CODE_NEG_REPLY:		case OCF_LINK_KEY_NEG_REPLY:			bdaddr_response_dump(level, frm);			return;		}		break;	case OGF_LINK_POLICY:		switch (ocf) {		case OCF_WRITE_LINK_POLICY:			generic_response_dump(level, frm);			return;		}		break;	case OGF_HOST_CTL:		switch (ocf) {		case OCF_READ_PIN_TYPE:			read_pin_type_dump(level, frm);			return;		case OCF_READ_STORED_LINK_KEY:			read_stored_link_key_dump(level, frm);			return;		case OCF_WRITE_STORED_LINK_KEY:			write_stored_link_key_dump(level, frm);			return;		case OCF_DELETE_STORED_LINK_KEY:			delete_stored_link_key_dump(level, frm);			return;		case OCF_READ_LOCAL_NAME:			read_local_name_dump(level, frm);			return;		case OCF_READ_CLASS_OF_DEV:			read_class_of_dev_dump(level, frm);			return;		case OCF_READ_VOICE_SETTING:			read_voice_setting_dump(level, frm);			return;		case OCF_READ_CURRENT_IAC_LAP:			read_current_iac_lap_dump(level, frm);			return;		case OCF_READ_SCAN_ENABLE:		case OCF_READ_AUTH_ENABLE:			read_scan_enable_dump(level, frm);			return;		case OCF_READ_PAGE_TIMEOUT:			read_page_timeout_dump(level, frm);			return;		case OCF_READ_PAGE_ACTIVITY:		case OCF_READ_INQ_ACTIVITY:			read_page_activity_dump(level, frm);			return;		case OCF_READ_ENCRYPT_MODE:		case OCF_READ_INQUIRY_MODE:		case OCF_READ_AFH_MODE:			read_inquiry_mode_dump(level, frm);			return;		case OCF_READ_LINK_SUPERVISION_TIMEOUT:			read_link_supervision_timeout_dump(level, frm);			return;		case OCF_READ_TRANSMIT_POWER_LEVEL:			read_transmit_power_level_dump(level, frm);			return;		case OCF_FLUSH:		case OCF_WRITE_LINK_SUPERVISION_TIMEOUT:			generic_response_dump(level, frm);			return;		case OCF_RESET:		case OCF_SET_EVENT_MASK:		case OCF_SET_EVENT_FLT:		case OCF_WRITE_PIN_TYPE:		case OCF_CREATE_NEW_UNIT_KEY:		case OCF_CHANGE_LOCAL_NAME:		case OCF_WRITE_CLASS_OF_DEV:		case OCF_WRITE_VOICE_SETTING:		case OCF_WRITE_CURRENT_IAC_LAP:		case OCF_WRITE_SCAN_ENABLE:		case OCF_WRITE_AUTH_ENABLE:		case OCF_WRITE_ENCRYPT_MODE:		case OCF_WRITE_PAGE_TIMEOUT:		case OCF_WRITE_PAGE_ACTIVITY:		case OCF_WRITE_INQ_ACTIVITY:		case OCF_WRITE_INQUIRY_MODE:		case OCF_WRITE_AFH_MODE:		case OCF_SET_AFH_CLASSIFICATION:			status_response_dump(level, frm);			return;		}		break;	case OGF_INFO_PARAM:		switch (ocf) {		case OCF_READ_LOCAL_VERSION:			read_local_version_dump(level, frm);			return;		case OCF_READ_LOCAL_COMMANDS:			read_local_commands_dump(level, frm);			return;		case OCF_READ_LOCAL_FEATURES:			read_local_features_dump(level, frm);			return;		case OCF_READ_LOCAL_EXT_FEATURES:			read_local_ext_features_dump(level, frm);			return;		case OCF_READ_BUFFER_SIZE:			read_buffer_size_dump(level, frm);			return;		case OCF_READ_BD_ADDR:			bdaddr_response_dump(level, frm);			return;		}		break;	case OGF_STATUS_PARAM:		switch (ocf) {		case OCF_READ_FAILED_CONTACT_COUNTER:		case OCF_RESET_FAILED_CONTACT_COUNTER:			status_response_dump(level, frm);			return;		case OCF_READ_LINK_QUALITY:			read_link_quality_dump(level, frm);			return;		case OCF_READ_RSSI:			read_rssi_dump(level, frm);			return;		case OCF_READ_AFH_MAP:			read_afh_map_dump(level, frm);			return;		case OCF_READ_CLOCK:			read_clock_dump(level, frm);			return;		}		break;	}	raw_dump(level, frm);}static inline void cmd_status_dump(int level, struct frame *frm){	evt_cmd_status *evt = frm->ptr;	uint16_t opcode = btohs(evt->opcode);	p_indent(level, frm);	printf("%s (0x%2.2x|0x%4.4x) status 0x%2.2x ncmd %d\n",		opcode2str(opcode),		cmd_opcode_ogf(opcode), cmd_opcode_ocf(opcode),		evt->status, evt->ncmd);	if (evt->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(evt->status));	}}static inline void hardware_error_dump(int level, struct frame *frm){	evt_hardware_error *evt = frm->ptr;	p_indent(level, frm);	printf("code %d\n", evt->code);}static inline void inq_result_dump(int level, struct frame *frm){	uint8_t num = get_u8(frm);	char addr[18];	int i;	for (i = 0; i < num; i++) {		inquiry_info *info = frm->ptr;		ba2str(&info->bdaddr, addr);		p_indent(level, frm);		printf("bdaddr %s mode %d clkoffset 0x%4.4x class 0x%2.2x%2.2x%2.2x\n",			addr, info->pscan_rep_mode, btohs(info->clock_offset),			info->dev_class[2], info->dev_class[1], info->dev_class[0]);		frm->ptr += INQUIRY_INFO_SIZE;		frm->len -= INQUIRY_INFO_SIZE;	}}static inline void conn_complete_dump(int level, struct frame *frm){	evt_conn_complete *evt = frm->ptr;	char addr[18];	ba2str(&evt->bdaddr, addr);	p_indent(level, frm);	printf("status 0x%2.2x handle %d bdaddr %s type %s encrypt 0x%2.2x\n",		evt->status, btohs(evt->handle), addr,		evt->link_type == 1 ? "ACL" : "SCO", evt->encr_mode);	if (evt->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(evt->status));	}}static inline void conn_request_dump(int level, struct frame *frm){	evt_conn_request *evt = frm->ptr;	char addr[18];	ba2str(&evt->bdaddr, addr);	p_indent(level, frm);	printf("bdaddr %s class 0x%2.2x%2.2x%2.2x type %s\n",		addr, evt->dev_class[2], evt->dev_class[1],		evt->dev_class[0], evt->link_type == 1 ? "ACL" : "SCO");}static inline void disconn_complete_dump(int level, struct frame *frm){	evt_disconn_complete *evt = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x handle %d reason 0x%2.2x\n",		evt->status, btohs(evt->handle), evt->reason);	if (evt->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(evt->status));	} else if (evt->reason > 0) {		p_indent(level, frm);		printf("Reason: %s\n", status2str(evt->reason));	}}static inline void remote_name_req_complete_dump(int level, struct frame *frm){	evt_remote_name_req_complete *evt = frm->ptr;	char addr[18], name[249];	int i;	ba2str(&evt->bdaddr, addr);	memset(name, 0, sizeof(name));	for (i = 0; i < 248 && evt->name[i]; i++)		if (isprint(evt->name[i]))			name[i] = evt->name[i];		else			name[i] = '.';	p_indent(level, frm);	printf("status 0x%2.2x bdaddr %s name '%s'\n", evt->status, addr, name);	if (evt->status > 0) {		p_indent(level, frm);		printf("Error: %s\n", status2str(evt->status));	}}static inline void master_link_key_complete_dump(int level, struct frame *frm){	evt_master_link_key_complete *evt = frm->ptr;	p_indent(level, frm);	printf("status 0x%2.2x handle %d flag %d\n",		evt->status, btohs(evt->handle), evt->key_flag);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -