test_ap_qosmap.py 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. # QoS Mapping tests
  2. # Copyright (c) 2013-2016, Jouni Malinen <j@w1.fi>
  3. #
  4. # This software may be distributed under the terms of the BSD license.
  5. # See README for more details.
  6. from remotehost import remote_compatible
  7. import time
  8. import logging
  9. logger = logging.getLogger()
  10. import hwsim_utils
  11. import hostapd
  12. from utils import HwsimSkip, alloc_fail, fail_test
  13. from wlantest import Wlantest
  14. def check_qos_map(ap, hapd, dev, sta, dscp, tid, ap_tid=None):
  15. if not ap_tid:
  16. ap_tid = tid
  17. bssid = ap['bssid']
  18. wt = Wlantest()
  19. wt.clear_sta_counters(bssid, sta)
  20. hwsim_utils.test_connectivity(dev, hapd, dscp=dscp, config=False)
  21. sleep_time = 0.02 if dev.hostname is None else 0.2
  22. time.sleep(sleep_time)
  23. tx = wt.get_tx_tid(bssid, sta, tid)
  24. if tx == 0:
  25. [ tx, rx ] = wt.get_tid_counters(bssid, sta)
  26. logger.info("Expected TX DSCP " + str(dscp) + " with TID " + str(tid) + " but counters: " + str(tx))
  27. raise Exception("No STA->AP data frame using the expected TID")
  28. rx = wt.get_rx_tid(bssid, sta, ap_tid)
  29. if rx == 0:
  30. [ tx, rx ] = wt.get_tid_counters(bssid, sta)
  31. logger.info("Expected RX DSCP " + str(dscp) + " with TID " + str(ap_tid) + " but counters: " + str(rx))
  32. raise Exception("No AP->STA data frame using the expected TID")
  33. @remote_compatible
  34. def test_ap_qosmap(dev, apdev):
  35. """QoS mapping"""
  36. drv_flags = dev[0].get_driver_status_field("capa.flags")
  37. if int(drv_flags, 0) & 0x40000000 == 0:
  38. raise HwsimSkip("Driver does not support QoS Map")
  39. ssid = "test-qosmap"
  40. params = { "ssid": ssid }
  41. params['qos_map_set'] = '53,2,22,6,8,15,0,7,255,255,16,31,32,39,255,255,40,47,48,55'
  42. hapd = hostapd.add_ap(apdev[0], params)
  43. dev[0].connect(ssid, key_mgmt="NONE", scan_freq="2412")
  44. time.sleep(0.1)
  45. addr = dev[0].p2p_interface_addr()
  46. dev[0].request("DATA_TEST_CONFIG 1")
  47. hapd.request("DATA_TEST_CONFIG 1")
  48. Wlantest.setup(hapd)
  49. check_qos_map(apdev[0], hapd, dev[0], addr, 53, 2)
  50. check_qos_map(apdev[0], hapd, dev[0], addr, 22, 6)
  51. check_qos_map(apdev[0], hapd, dev[0], addr, 8, 0)
  52. check_qos_map(apdev[0], hapd, dev[0], addr, 15, 0)
  53. check_qos_map(apdev[0], hapd, dev[0], addr, 0, 1)
  54. check_qos_map(apdev[0], hapd, dev[0], addr, 7, 1)
  55. check_qos_map(apdev[0], hapd, dev[0], addr, 16, 3)
  56. check_qos_map(apdev[0], hapd, dev[0], addr, 31, 3)
  57. check_qos_map(apdev[0], hapd, dev[0], addr, 32, 4)
  58. check_qos_map(apdev[0], hapd, dev[0], addr, 39, 4)
  59. check_qos_map(apdev[0], hapd, dev[0], addr, 40, 6)
  60. check_qos_map(apdev[0], hapd, dev[0], addr, 47, 6)
  61. check_qos_map(apdev[0], hapd, dev[0], addr, 48, 7)
  62. check_qos_map(apdev[0], hapd, dev[0], addr, 55, 7)
  63. hapd.request("SET_QOS_MAP_SET 22,6,8,15,0,7,255,255,16,31,32,39,255,255,40,47,48,55")
  64. hapd.request("SEND_QOS_MAP_CONF " + dev[0].get_status_field("address"))
  65. check_qos_map(apdev[0], hapd, dev[0], addr, 53, 7)
  66. check_qos_map(apdev[0], hapd, dev[0], addr, 22, 6)
  67. check_qos_map(apdev[0], hapd, dev[0], addr, 48, 7)
  68. check_qos_map(apdev[0], hapd, dev[0], addr, 55, 7)
  69. check_qos_map(apdev[0], hapd, dev[0], addr, 56, 56 >> 3)
  70. check_qos_map(apdev[0], hapd, dev[0], addr, 63, 63 >> 3)
  71. dev[0].request("DATA_TEST_CONFIG 0")
  72. hapd.request("DATA_TEST_CONFIG 0")
  73. @remote_compatible
  74. def test_ap_qosmap_default(dev, apdev):
  75. """QoS mapping with default values"""
  76. ssid = "test-qosmap-default"
  77. params = { "ssid": ssid }
  78. hapd = hostapd.add_ap(apdev[0], params)
  79. dev[0].connect(ssid, key_mgmt="NONE", scan_freq="2412")
  80. addr = dev[0].p2p_interface_addr()
  81. dev[0].request("DATA_TEST_CONFIG 1")
  82. hapd.request("DATA_TEST_CONFIG 1")
  83. Wlantest.setup(hapd)
  84. for dscp in [ 0, 7, 8, 15, 16, 23, 24, 31, 32, 39, 40, 47, 48, 55, 56, 63]:
  85. check_qos_map(apdev[0], hapd, dev[0], addr, dscp, dscp >> 3)
  86. dev[0].request("DATA_TEST_CONFIG 0")
  87. hapd.request("DATA_TEST_CONFIG 0")
  88. @remote_compatible
  89. def test_ap_qosmap_default_acm(dev, apdev):
  90. """QoS mapping with default values and ACM=1 for VO/VI"""
  91. ssid = "test-qosmap-default"
  92. params = { "ssid": ssid,
  93. "wmm_ac_bk_aifs": "7",
  94. "wmm_ac_bk_cwmin": "4",
  95. "wmm_ac_bk_cwmax": "10",
  96. "wmm_ac_bk_txop_limit": "0",
  97. "wmm_ac_bk_acm": "0",
  98. "wmm_ac_be_aifs": "3",
  99. "wmm_ac_be_cwmin": "4",
  100. "wmm_ac_be_cwmax": "10",
  101. "wmm_ac_be_txop_limit": "0",
  102. "wmm_ac_be_acm": "0",
  103. "wmm_ac_vi_aifs": "2",
  104. "wmm_ac_vi_cwmin": "3",
  105. "wmm_ac_vi_cwmax": "4",
  106. "wmm_ac_vi_txop_limit": "94",
  107. "wmm_ac_vi_acm": "1",
  108. "wmm_ac_vo_aifs": "2",
  109. "wmm_ac_vo_cwmin": "2",
  110. "wmm_ac_vo_cwmax": "2",
  111. "wmm_ac_vo_txop_limit": "47",
  112. "wmm_ac_vo_acm": "1" }
  113. hapd = hostapd.add_ap(apdev[0], params)
  114. dev[0].connect(ssid, key_mgmt="NONE", scan_freq="2412")
  115. addr = dev[0].p2p_interface_addr()
  116. dev[0].request("DATA_TEST_CONFIG 1")
  117. hapd.request("DATA_TEST_CONFIG 1")
  118. Wlantest.setup(hapd)
  119. for dscp in [ 0, 7, 8, 15, 16, 23, 24, 31, 32, 39, 40, 47, 48, 55, 56, 63]:
  120. ap_tid = dscp >> 3
  121. tid = ap_tid
  122. # downgrade VI/VO to BE
  123. if tid in [ 4, 5, 6, 7 ]:
  124. tid = 3
  125. check_qos_map(apdev[0], hapd, dev[0], addr, dscp, tid, ap_tid)
  126. dev[0].request("DATA_TEST_CONFIG 0")
  127. hapd.request("DATA_TEST_CONFIG 0")
  128. @remote_compatible
  129. def test_ap_qosmap_invalid(dev, apdev):
  130. """QoS mapping ctrl_iface error handling"""
  131. ssid = "test-qosmap"
  132. params = { "ssid": ssid }
  133. hapd = hostapd.add_ap(apdev[0], params)
  134. if "FAIL" not in hapd.request("SEND_QOS_MAP_CONF 00:11:22:33:44:55"):
  135. raise Exception("Unexpected SEND_QOS_MAP_CONF success")
  136. if "FAIL" not in hapd.request("SET_QOS_MAP_SET "):
  137. raise Exception("Unexpected SET_QOS_MAP_SET success")
  138. if "FAIL" not in hapd.request("SET_QOS_MAP_SET 1,2,3"):
  139. raise Exception("Unexpected SET_QOS_MAP_SET success")
  140. if "FAIL" not in hapd.request("SET_QOS_MAP_SET 1,-2,3"):
  141. raise Exception("Unexpected SET_QOS_MAP_SET success")
  142. if "FAIL" not in hapd.request("SET_QOS_MAP_SET 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59"):
  143. raise Exception("Unexpected SET_QOS_MAP_SET success")
  144. if "FAIL" not in hapd.request("SET_QOS_MAP_SET 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21"):
  145. raise Exception("Unexpected SET_QOS_MAP_SET success")
  146. if "FAIL" in hapd.request("SET_QOS_MAP_SET 22,6,8,15,0,7,255,255,16,31,32,39,255,255,40,47,48,55"):
  147. raise Exception("Unexpected SET_QOS_MAP_SET failure")
  148. if "FAIL" not in hapd.request("SEND_QOS_MAP_CONF 00:11:22:33:44:55"):
  149. raise Exception("Unexpected SEND_QOS_MAP_CONF success")
  150. if "FAIL" not in hapd.request("SEND_QOS_MAP_CONF 00:11:22:33:44"):
  151. raise Exception("Unexpected SEND_QOS_MAP_CONF success")
  152. with fail_test(hapd, 1, "hostapd_ctrl_iface_set_qos_map_set"):
  153. if "FAIL" not in hapd.request("SET_QOS_MAP_SET 22,6,8,15,0,7,255,255,16,31,32,39,255,255,40,47,48,55"):
  154. raise Exception("SET_QOS_MAP_SET accepted during forced driver failure")
  155. dev[0].connect(ssid, key_mgmt="NONE", scan_freq="2412")
  156. with alloc_fail(hapd, 1,
  157. "wpabuf_alloc;hostapd_ctrl_iface_send_qos_map_conf"):
  158. if "FAIL" not in hapd.request("SEND_QOS_MAP_CONF " + dev[0].own_addr()):
  159. raise Exception("SEND_QOS_MAP_CONF accepted during OOM")