struct ieee80211_key_conf *key)
 {
        struct mt792x_dev *dev = mt792x_hw_dev(hw);
+       struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
+       struct mt792x_sta *msta = sta ? (struct mt792x_sta *)sta->drv_priv :
+                                 &mvif->sta;
        int err;
 
        /* The hardware does not support per-STA RX GTK, fallback
 
        mt792x_mutex_acquire(dev);
 
-       err = mt7925_set_link_key(hw, cmd, vif, sta, key, vif->bss_conf.link_id);
+       if (ieee80211_vif_is_mld(vif)) {
+               unsigned int link_id;
+               unsigned long add;
+
+               add = key->link_id != -1 ? BIT(key->link_id) : msta->valid_links;
+
+               for_each_set_bit(link_id, &add, IEEE80211_MLD_MAX_NUM_LINKS) {
+                       err = mt7925_set_link_key(hw, cmd, vif, sta, key, link_id);
+                       if (err < 0)
+                               break;
+               }
+       } else {
+               err = mt7925_set_link_key(hw, cmd, vif, sta, key, vif->bss_conf.link_id);
+       }
 
        mt792x_mutex_release(dev);