1sequence! { procedure, context, 2 // ACL Connection Established 3 Lower Tester -> IUT: IoCapabilityReq { 4 transaction_id: 0, 5 io_capabilities: 0x01, 6 oob_authentication_data: 0x00, 7 authentication_requirement: 0x01, 8 } 9 IUT -> Upper Tester: IoCapabilityResponse { 10 bd_addr: context.peer_address(), 11 io_capability: IoCapability::DisplayYesNo, 12 oob_data_present: OobDataPresent::NotPresent, 13 authentication_requirements: AuthenticationRequirements::NoBondingMitmProtection, 14 } 15 IUT -> Upper Tester: IoCapabilityRequest { 16 bd_addr: context.peer_address(), 17 } 18 Upper Tester -> IUT: IoCapabilityRequestReply { 19 bd_addr: context.peer_address(), 20 io_capability: IoCapability::DisplayYesNo, 21 oob_present: OobDataPresent::NotPresent, 22 authentication_requirements: AuthenticationRequirements::NoBondingMitmProtection, 23 } 24 IUT -> Upper Tester: IoCapabilityRequestReplyComplete { 25 num_hci_command_packets: 1, 26 status: ErrorCode::Success, 27 bd_addr: context.peer_address(), 28 } 29 IUT -> Lower Tester: IoCapabilityRes { 30 transaction_id: 0, 31 io_capabilities: 0x01, 32 oob_authentication_data: 0x00, 33 authentication_requirement: 0x01, 34 } 35 // Public Key Exchange 36 Lower Tester -> IUT: EncapsulatedHeader { 37 transaction_id: 0, 38 major_type: 1, 39 minor_type: 1, 40 payload_length: 48, 41 } 42 IUT -> Lower Tester: Accepted { 43 transaction_id: 0, 44 accepted_opcode: Opcode::EncapsulatedHeader, 45 } 46 repeat 3 times with (part in peer_p192_public_key()) { 47 Lower Tester -> IUT: EncapsulatedPayload { 48 transaction_id: 0, 49 data: part, 50 } 51 IUT -> Lower Tester: Accepted { 52 transaction_id: 0, 53 accepted_opcode: Opcode::EncapsulatedPayload, 54 } 55 } 56 IUT -> Lower Tester: EncapsulatedHeader { 57 transaction_id: 0, 58 major_type: 1, 59 minor_type: 1, 60 payload_length: 48, 61 } 62 Lower Tester -> IUT: Accepted { 63 transaction_id: 0, 64 accepted_opcode: Opcode::EncapsulatedHeader, 65 } 66 repeat 3 times with (part in local_p192_public_key(&context)) { 67 IUT -> Lower Tester: EncapsulatedPayload { 68 transaction_id: 0, 69 data: part, 70 } 71 Lower Tester -> IUT: Accepted { 72 transaction_id: 0, 73 accepted_opcode: Opcode::EncapsulatedPayload, 74 } 75 } 76 // Authentication Stage 1: Numeric Comparison Protocol 77 IUT -> Lower Tester: SimplePairingConfirm { 78 transaction_id: 0, 79 commitment_value: [0; 16], 80 } 81 Lower Tester -> IUT: SimplePairingNumber { 82 transaction_id: 0, 83 nonce: [0; 16], 84 } 85 IUT -> Lower Tester: Accepted { 86 transaction_id: 0, 87 accepted_opcode: Opcode::SimplePairingNumber, 88 } 89 IUT -> Lower Tester: SimplePairingNumber { 90 transaction_id: 0, 91 nonce: [0; 16], 92 } 93 Lower Tester -> IUT: Accepted { 94 transaction_id: 0, 95 accepted_opcode: Opcode::SimplePairingNumber, 96 } 97 IUT -> Upper Tester: UserConfirmationRequest { bd_addr: context.peer_address(), numeric_value: 0 } 98 Upper Tester -> IUT: UserConfirmationRequestReply { bd_addr: context.peer_address() } 99 IUT -> Upper Tester: UserConfirmationRequestReplyComplete { 100 num_hci_command_packets: 1, 101 status: ErrorCode::Success, 102 bd_addr: context.peer_address(), 103 } 104 // Authentication Stage 2 105 Lower Tester -> IUT: DhkeyCheck { 106 transaction_id: 0, 107 confirmation_value: [0; 16], 108 } 109 IUT -> Lower Tester: Accepted { transaction_id: 0, accepted_opcode: Opcode::DhkeyCheck } 110 IUT -> Lower Tester: DhkeyCheck { 111 transaction_id: 0, 112 confirmation_value: [0; 16], 113 } 114 Lower Tester -> IUT: Accepted { transaction_id: 0, accepted_opcode: Opcode::DhkeyCheck } 115 IUT -> Upper Tester: SimplePairingComplete { 116 status: ErrorCode::Success, 117 bd_addr: context.peer_address(), 118 } 119 // Link Key Calculation 120 Lower Tester -> IUT: AuRand { 121 transaction_id: 0, 122 random_number: [0; 16], 123 } 124 IUT -> Lower Tester: Sres { 125 transaction_id: 0, 126 authentication_rsp: [0; 4], 127 } 128 IUT -> Lower Tester: AuRand { 129 transaction_id: 0, 130 random_number: [0; 16], 131 } 132 Lower Tester -> IUT: Sres { 133 transaction_id: 0, 134 authentication_rsp: [0; 4], 135 } 136 IUT -> Upper Tester: LinkKeyNotification { 137 bd_addr: context.peer_address(), 138 key_type: KeyType::AuthenticatedP192, 139 link_key: [0; 16], 140 } 141} 142