/**
  * enum iwl_location_cipher - location cipher selection
  * @IWL_LOCATION_CIPHER_CCMP_128: CCMP 128
- * @IWL_LOCATION_CIPHER_CCMP_256: CCMP 256
  * @IWL_LOCATION_CIPHER_GCMP_128: GCMP 128
  * @IWL_LOCATION_CIPHER_GCMP_256: GCMP 256
  */
 enum iwl_location_cipher {
        IWL_LOCATION_CIPHER_CCMP_128,
-       IWL_LOCATION_CIPHER_CCMP_256,
        IWL_LOCATION_CIPHER_GCMP_128,
        IWL_LOCATION_CIPHER_GCMP_256,
 };
  * @samples_per_burst: the number of FTMs pairs in single Burst (1-31);
  * @num_of_bursts: Recommended value to be sent to the AP. 2s Exponent of
  *     the number of measurement iterations (min 2^0 = 1, max 2^14)
- * @reserved: For alignment and future use
+ * @sta_id: the station id of the AP. Only relevant when associated to the AP,
+ *     otherwise should be set to &IWL_MVM_INVALID_STA.
  * @cipher: pairwise cipher suite for secured measurement.
  *          &enum iwl_location_cipher.
  * @hltk: HLTK to be used for secured 11az measurement
  *         If &IWL_INITIATOR_AP_FLAGS_USE_CALIB is set, the fw will use the
  *         calibration value that corresponds to the rx bandwidth of the FTM
  *         frame.
- * @reserved2: For alignment and future use.
+ * @beacon_interval: beacon interval of the AP in TUs. Only required if
+ *     &IWL_INITIATOR_AP_FLAGS_TB is set.
  */
 struct iwl_tof_range_req_ap_entry {
        __le32 initiator_ap_flags;
        __le16 burst_period;
        u8 samples_per_burst;
        u8 num_of_bursts;
-       u8 reserved;
+       u8 sta_id;
        u8 cipher;
        u8 hltk[HLTK_11AZ_LEN];
        u8 tk[TK_11AZ_LEN];
        __le16 calib[IWL_TOF_BW_NUM];
-       __le16 reserved2;
-} __packed; /* LOCATION_RANGE_REQ_AP_ENTRY_CMD_API_S_VER_5 */
+       __le16 beacon_interval;
+} __packed; /* LOCATION_RANGE_REQ_AP_ENTRY_CMD_API_S_VER_6 */
 
 /**
  * enum iwl_tof_response_mode
 
 }
 
 static int
-iwl_mvm_ftm_put_target(struct iwl_mvm *mvm,
+iwl_mvm_ftm_put_target_v4(struct iwl_mvm *mvm,
+                         struct cfg80211_pmsr_request_peer *peer,
+                         struct iwl_tof_range_req_ap_entry_v4 *target)
+{
+       int ret;
+
+       ret = iwl_mvm_ftm_target_chandef_v2(mvm, peer, &target->channel_num,
+                                           &target->format_bw,
+                                           &target->ctrl_ch_position);
+       if (ret)
+               return ret;
+
+       iwl_mvm_ftm_put_target_common(mvm, peer, (void *)target);
+
+       return 0;
+}
+
+static int
+iwl_mvm_ftm_put_target(struct iwl_mvm *mvm, struct ieee80211_vif *vif,
                       struct cfg80211_pmsr_request_peer *peer,
-                      struct iwl_tof_range_req_ap_entry_v4 *target)
+                      struct iwl_tof_range_req_ap_entry *target)
 {
        int ret;
 
 
        iwl_mvm_ftm_put_target_common(mvm, peer, (void *)target);
 
+       if (vif->bss_conf.assoc &&
+           !memcmp(peer->addr, vif->bss_conf.bssid, ETH_ALEN)) {
+               struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif);
+
+               target->sta_id = mvmvif->ap_sta_id;
+       } else {
+               target->sta_id = IWL_MVM_INVALID_STA;
+       }
+
+       /*
+        * TODO: Beacon interval is currently unknown, so use the common value
+        * of 100 TUs.
+        */
+       target->beacon_interval = cpu_to_le16(100);
        return 0;
 }
 
        for (i = 0; i < cmd.num_of_ap; i++) {
                struct cfg80211_pmsr_request_peer *peer = &req->peers[i];
 
-               err = iwl_mvm_ftm_put_target(mvm, peer, &cmd.ap[i]);
+               err = iwl_mvm_ftm_put_target_v4(mvm, peer, &cmd.ap[i]);
                if (err)
                        return err;
        }
 
        for (i = 0; i < cmd.num_of_ap; i++) {
                struct cfg80211_pmsr_request_peer *peer = &req->peers[i];
+               struct iwl_tof_range_req_ap_entry *target = &cmd.ap[i];
 
-               err = iwl_mvm_ftm_put_target(mvm, peer, (void *)&cmd.ap[i]);
+               err = iwl_mvm_ftm_put_target(mvm, vif, peer, target);
                if (err)
                        return err;
        }
 
                switch (cmd_ver) {
                case 9:
+               case 10:
                        err = iwl_mvm_ftm_start_v9(mvm, vif, req);
                        break;
                case 8: