* interface.
  */
 enum ath_fft_sample_type {
-       ATH_FFT_SAMPLE_HT20 = 0,
+       ATH_FFT_SAMPLE_HT20 = 1,
 };
 
 struct fft_sample_tlv {
 struct fft_sample_ht20 {
        struct fft_sample_tlv tlv;
 
-       u8 __alignment;
+       u8 max_exp;
 
        u16 freq;
        s8 rssi;
 
        u64 tsf;
 
-       u16 data[SPECTRAL_HT20_NUM_BINS];
+       u8 data[SPECTRAL_HT20_NUM_BINS];
 } __packed;
 
 void ath9k_tasklet(unsigned long data);
 
 void ath_debug_send_fft_sample(struct ath_softc *sc,
                               struct fft_sample_tlv *fft_sample_tlv)
 {
+       int length;
        if (!sc->rfs_chan_spec_scan)
                return;
 
-       relay_write(sc->rfs_chan_spec_scan, fft_sample_tlv,
-                   fft_sample_tlv->length + sizeof(*fft_sample_tlv));
+       length = __be16_to_cpu(fft_sample_tlv->length) +
+                sizeof(*fft_sample_tlv);
+       relay_write(sc->rfs_chan_spec_scan, fft_sample_tlv, length);
 }
 
 static struct rchan_callbacks rfs_spec_scan_cb = {
 
        struct ath_radar_info *radar_info;
        struct ath_ht20_mag_info *mag_info;
        int len = rs->rs_datalen;
-       int i, dc_pos;
+       int dc_pos;
 
        /* AR9280 and before report via ATH9K_PHYERR_RADAR, AR93xx and newer
         * via ATH9K_PHYERR_SPECTRAL. Haven't seen ATH9K_PHYERR_FALSE_RADAR_EXT
 
        fft_sample.tlv.type = ATH_FFT_SAMPLE_HT20;
        fft_sample.tlv.length = sizeof(fft_sample) - sizeof(fft_sample.tlv);
+       fft_sample.tlv.length = __cpu_to_be16(fft_sample.tlv.length);
 
-       fft_sample.freq = ah->curchan->chan->center_freq;
+       fft_sample.freq = __cpu_to_be16(ah->curchan->chan->center_freq);
        fft_sample.rssi = fix_rssi_inv_only(rs->rs_rssi_ctl0);
        fft_sample.noise = ah->noise;
 
        /* mag data is at the end of the frame, in front of radar_info */
        mag_info = ((struct ath_ht20_mag_info *)radar_info) - 1;
 
-       /* Apply exponent and grab further auxiliary information. */
-       for (i = 0; i < SPECTRAL_HT20_NUM_BINS; i++)
-               fft_sample.data[i] = bins[i] << mag_info->max_exp;
+       /* copy raw bins without scaling them */
+       memcpy(fft_sample.data, bins, SPECTRAL_HT20_NUM_BINS);
+       fft_sample.max_exp = mag_info->max_exp & 0xf;
 
        fft_sample.max_magnitude = spectral_max_magnitude(mag_info->all_bins);
+       fft_sample.max_magnitude = __cpu_to_be16(fft_sample.max_magnitude);
        fft_sample.max_index = spectral_max_index(mag_info->all_bins);
        fft_sample.bitmap_weight = spectral_bitmap_weight(mag_info->all_bins);
-       fft_sample.tsf = tsf;
+       fft_sample.tsf = __cpu_to_be64(tsf);
 
        ath_debug_send_fft_sample(sc, &fft_sample.tlv);
        return 1;