wifi: rtw89: mcc: add courtesy mechanism conditions to P2P roles
authorZong-Zhe Yang <kevin_yang@realtek.com>
Sun, 11 May 2025 03:52:14 +0000 (11:52 +0800)
committerPing-Ke Shih <pkshih@realtek.com>
Fri, 16 May 2025 00:43:22 +0000 (08:43 +0800)
In one enablement of courtesy mechanism, there is one provider and
one receiver. And, receiver can use the provider's time in a given
period. But, to make P2P NoA protocol work as expected as possible,
GO should be present at the time it doesn't announce absent, and GC
should not use the time when GO announces absent. So, don't enable
courtesy mechanism if provider is GO or receiver is GC.

Signed-off-by: Zong-Zhe Yang <kevin_yang@realtek.com>
Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
Link: https://patch.msgid.link/20250511035217.10410-4-pkshih@realtek.com
drivers/net/wireless/realtek/rtw89/chan.c

index e733564abc7af85502b1862823ea02b231b23148..e09541ceb504c723f64fba351efdccf626b5b51e 100644 (file)
@@ -961,6 +961,15 @@ static int rtw89_mcc_fill_all_roles(struct rtw89_dev *rtwdev)
        return 0;
 }
 
+static bool rtw89_mcc_can_courtesy(const struct rtw89_mcc_role *provider,
+                                  const struct rtw89_mcc_role *receiver)
+{
+       if (provider->is_go || receiver->is_gc)
+               return false;
+
+       return true;
+}
+
 static void rtw89_mcc_assign_pattern(struct rtw89_dev *rtwdev,
                                     const struct rtw89_mcc_pattern *new)
 {
@@ -980,7 +989,7 @@ static void rtw89_mcc_assign_pattern(struct rtw89_dev *rtwdev,
        *pattern = *new;
        memset(&pattern->courtesy, 0, sizeof(pattern->courtesy));
 
-       if (RTW89_MCC_REQ_COURTESY(pattern, aux)) {
+       if (RTW89_MCC_REQ_COURTESY(pattern, aux) && rtw89_mcc_can_courtesy(ref, aux)) {
                crtz = &pattern->courtesy.ref;
                ref->crtz = crtz;
 
@@ -994,7 +1003,7 @@ static void rtw89_mcc_assign_pattern(struct rtw89_dev *rtwdev,
                ref->crtz = NULL;
        }
 
-       if (RTW89_MCC_REQ_COURTESY(pattern, ref)) {
+       if (RTW89_MCC_REQ_COURTESY(pattern, ref) && rtw89_mcc_can_courtesy(aux, ref)) {
                crtz = &pattern->courtesy.aux;
                aux->crtz = crtz;