ath_reserve_key_cache_slot() was obviously supposed to return an index
to a free slot, not reserved one. This could have caused problems with
hardware revisions that use splitmic.
Signed-off-by: Jouni Malinen <jouni.malinen@atheros.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
                            (test_bit(i , sc->sc_keymap) ||
                             test_bit(i + 32, sc->sc_keymap) ||
                             test_bit(i + 64 + 32, sc->sc_keymap)))
-                               return i;
+                               return i + 64;
                        if (!test_bit(i + 64 + 32, sc->sc_keymap) &&
                            (test_bit(i, sc->sc_keymap) ||
                             test_bit(i + 32, sc->sc_keymap) ||
                             test_bit(i + 64, sc->sc_keymap)))
-                               return i;
+                               return i + 64 + 32;
                }
        } else {
                for (i = IEEE80211_WEP_NKID; i < sc->sc_keymax / 2; i++) {