AI Trajectory


Trajectory: (Expand/Collapse All)
Seq Timestamp Type Name Duration
0/0 2026/06/26 16:07 flow patch-triage
0m Args:
null

Results:
{
  "EnableConfigs": null,
  "FocusSymbols": [],
  "Reasoning": "The patch only replaces a custom BOOL_TO_STR macro with the standard str_true_false helper in tracepoints. This is a purely decorative change that does not alter any functional execution flow.",
  "WorthFuzzing": false
}

1/1 2026/06/26 16:07 action read-patch-diff
0m Args:
null

Results:
{
  "PatchDiff": "commit 91f6ef0f31abb26bf36c5a07de4491de7d3afa34\nAuthor: syz-cluster \u003ctriage@syzkaller.com\u003e\nDate:   Fri Jun 26 16:07:14 2026 +0000\n\n    syz-cluster: applied patch under review\n\ndiff --git a/net/wireless/trace.h b/net/wireless/trace.h\nindex 94944f2a39a4d6..befab459852ad0 100644\n--- a/net/wireless/trace.h\n+++ b/net/wireless/trace.h\n@@ -14,6 +14,7 @@\n \n #include \u003clinux/rtnetlink.h\u003e\n #include \u003clinux/etherdevice.h\u003e\n+#include \u003clinux/string_choices.h\u003e\n #include \u003cnet/cfg80211.h\u003e\n #include \"core.h\"\n \n@@ -228,7 +229,6 @@\n \t\t__entry-\u003eplink_state = sinfo-\u003eplink_state;\t       \\\n \t} while (0)\n \n-#define BOOL_TO_STR(bo) (bo) ? \"true\" : \"false\"\n \n #define QOS_MAP_ENTRY __field(u8, num_des)\t\t\t\\\n \t\t      __array(u8, dscp_exception,\t\t\\\n@@ -578,7 +578,7 @@ DECLARE_EVENT_CLASS(key_handle,\n \tTP_printk(WIPHY_PR_FMT \", \" WDEV_PR_FMT \", link_id: %d, \"\n \t\t  \"key_index: %u, pairwise: %s, mac addr: %pM\",\n \t\t  WIPHY_PR_ARG, WDEV_PR_ARG, __entry-\u003elink_id,\n-\t\t  __entry-\u003ekey_index, BOOL_TO_STR(__entry-\u003epairwise),\n+\t\t  __entry-\u003ekey_index, str_true_false(__entry-\u003epairwise),\n \t\t  __entry-\u003emac_addr)\n );\n \n@@ -621,7 +621,7 @@ TRACE_EVENT(rdev_add_key,\n \t\t  \"mac addr: %pM\",\n \t\t  WIPHY_PR_ARG, WDEV_PR_ARG, __entry-\u003elink_id,\n \t\t  __entry-\u003ekey_index, __entry-\u003emode,\n-\t\t  BOOL_TO_STR(__entry-\u003epairwise), __entry-\u003emac_addr)\n+\t\t  str_true_false(__entry-\u003epairwise), __entry-\u003emac_addr)\n );\n \n TRACE_EVENT(rdev_set_default_key,\n@@ -647,8 +647,8 @@ TRACE_EVENT(rdev_set_default_key,\n \tTP_printk(WIPHY_PR_FMT \", \" NETDEV_PR_FMT \", link_id: %d, \"\n \t\t  \"key index: %u, unicast: %s, multicast: %s\",\n \t\t  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry-\u003elink_id,\n-\t\t  __entry-\u003ekey_index, BOOL_TO_STR(__entry-\u003eunicast),\n-\t\t  BOOL_TO_STR(__entry-\u003emulticast))\n+\t\t  __entry-\u003ekey_index, str_true_false(__entry-\u003eunicast),\n+\t\t  str_true_false(__entry-\u003emulticast))\n );\n \n TRACE_EVENT(rdev_set_default_mgmt_key,\n@@ -733,7 +733,7 @@ TRACE_EVENT(rdev_start_ap,\n \t\t  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry-\u003essid, CHAN_DEF_PR_ARG,\n \t\t  __entry-\u003ebeacon_interval, __entry-\u003edtim_period,\n \t\t  __entry-\u003ehidden_ssid, __entry-\u003ewpa_ver,\n-\t\t  BOOL_TO_STR(__entry-\u003eprivacy), __entry-\u003eauth_type,\n+\t\t  str_true_false(__entry-\u003eprivacy), __entry-\u003eauth_type,\n \t\t  __entry-\u003einactivity_timeout, __entry-\u003elink_id)\n );\n \n@@ -1469,7 +1469,7 @@ TRACE_EVENT(rdev_assoc,\n \tTP_printk(WIPHY_PR_FMT \", \" NETDEV_PR_FMT \", bssid: %pM\"\n \t\t  \", previous bssid: %pM, use mfp: %s, flags: 0x%x\",\n \t\t  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry-\u003ebssid,\n-\t\t  __entry-\u003eprev_bssid, BOOL_TO_STR(__entry-\u003euse_mfp),\n+\t\t  __entry-\u003eprev_bssid, str_true_false(__entry-\u003euse_mfp),\n \t\t  __entry-\u003eflags)\n );\n \n@@ -1518,7 +1518,7 @@ TRACE_EVENT(rdev_disassoc,\n \t\t  \", reason: %u, local state change: %s\",\n \t\t  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry-\u003ebssid,\n \t\t  __entry-\u003ereason_code,\n-\t\t  BOOL_TO_STR(__entry-\u003elocal_state_change))\n+\t\t  str_true_false(__entry-\u003elocal_state_change))\n );\n \n TRACE_EVENT(rdev_mgmt_tx_cancel_wait,\n@@ -1591,7 +1591,7 @@ TRACE_EVENT(rdev_connect,\n \t\t  \", ssid: %s, auth type: %d, privacy: %s, wpa versions: %u, \"\n \t\t  \"flags: 0x%x, previous bssid: %pM\",\n \t\t  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry-\u003ebssid, __entry-\u003essid,\n-\t\t  __entry-\u003eauth_type, BOOL_TO_STR(__entry-\u003eprivacy),\n+\t\t  __entry-\u003eauth_type, str_true_false(__entry-\u003eprivacy),\n \t\t  __entry-\u003ewpa_versions, __entry-\u003eflags, __entry-\u003eprev_bssid)\n );\n \n@@ -2033,7 +2033,7 @@ TRACE_EVENT(rdev_tdls_mgmt,\n \t\t  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry-\u003epeer,\n \t\t  __entry-\u003elink_id, __entry-\u003eaction_code, __entry-\u003edialog_token,\n \t\t  __entry-\u003estatus_code, __entry-\u003epeer_capability,\n-\t\t  BOOL_TO_STR(__entry-\u003einitiator),\n+\t\t  str_true_false(__entry-\u003einitiator),\n \t\t  ((u8 *)__get_dynamic_array(buf))[0])\n );\n \n@@ -2246,9 +2246,9 @@ TRACE_EVENT(rdev_mgmt_tx,\n \tTP_printk(WIPHY_PR_FMT \", \" WDEV_PR_FMT \", \" CHAN_PR_FMT \", offchan: %s,\"\n \t\t  \" wait: %u, no cck: %s, dont wait for ack: %s\",\n \t\t  WIPHY_PR_ARG, WDEV_PR_ARG, CHAN_PR_ARG,\n-\t\t  BOOL_TO_STR(__entry-\u003eoffchan), __entry-\u003ewait,\n-\t\t  BOOL_TO_STR(__entry-\u003eno_cck),\n-\t\t  BOOL_TO_STR(__entry-\u003edont_wait_for_ack))\n+\t\t  str_true_false(__entry-\u003eoffchan), __entry-\u003ewait,\n+\t\t  str_true_false(__entry-\u003eno_cck),\n+\t\t  str_true_false(__entry-\u003edont_wait_for_ack))\n );\n \n TRACE_EVENT(rdev_tx_control_port,\n@@ -2276,7 +2276,7 @@ TRACE_EVENT(rdev_tx_control_port,\n \t\t  \" proto: 0x%x, unencrypted: %s, link: %d\",\n \t\t  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry-\u003edest,\n \t\t  be16_to_cpu(__entry-\u003eproto),\n-\t\t  BOOL_TO_STR(__entry-\u003eunencrypted),\n+\t\t  str_true_false(__entry-\u003eunencrypted),\n \t\t  __entry-\u003elink_id)\n );\n \n@@ -2894,7 +2894,7 @@ TRACE_EVENT(rdev_set_multicast_to_unicast,\n \t),\n \tTP_printk(WIPHY_PR_FMT \", \" NETDEV_PR_FMT \", unicast: %s\",\n \t\t  WIPHY_PR_ARG, NETDEV_PR_ARG,\n-\t\t  BOOL_TO_STR(__entry-\u003eenabled))\n+\t\t  str_true_false(__entry-\u003eenabled))\n );\n \n DEFINE_EVENT(wiphy_wdev_evt, rdev_get_txq_stats,\n@@ -3225,7 +3225,7 @@ TRACE_EVENT(cfg80211_return_bool,\n \tTP_fast_assign(\n \t\t__entry-\u003eret = ret;\n \t),\n-\tTP_printk(\"returned %s\", BOOL_TO_STR(__entry-\u003eret))\n+\tTP_printk(\"returned %s\", str_true_false(__entry-\u003eret))\n );\n \n DECLARE_EVENT_CLASS(cfg80211_netdev_mac_evt,\n@@ -3500,7 +3500,7 @@ TRACE_EVENT(cfg80211_mgmt_tx_status,\n \t\t__entry-\u003eack = ack;\n \t),\n \tTP_printk(WDEV_PR_FMT\", cookie: %llu, ack: %s\",\n-\t\t  WDEV_PR_ARG, __entry-\u003ecookie, BOOL_TO_STR(__entry-\u003eack))\n+\t\t  WDEV_PR_ARG, __entry-\u003ecookie, str_true_false(__entry-\u003eack))\n );\n \n TRACE_EVENT(cfg80211_control_port_tx_status,\n@@ -3517,7 +3517,7 @@ TRACE_EVENT(cfg80211_control_port_tx_status,\n \t\t__entry-\u003eack = ack;\n \t),\n \tTP_printk(WDEV_PR_FMT\", cookie: %llu, ack: %s\",\n-\t\t  WDEV_PR_ARG, __entry-\u003ecookie, BOOL_TO_STR(__entry-\u003eack))\n+\t\t  WDEV_PR_ARG, __entry-\u003ecookie, str_true_false(__entry-\u003eack))\n );\n \n TRACE_EVENT(cfg80211_rx_control_port,\n@@ -3542,7 +3542,7 @@ TRACE_EVENT(cfg80211_rx_control_port,\n \t),\n \tTP_printk(NETDEV_PR_FMT \", len=%d, %pM, proto: 0x%x, unencrypted: %s, link: %d\",\n \t\t  NETDEV_PR_ARG, __entry-\u003elen, __entry-\u003efrom,\n-\t\t  __entry-\u003eproto, BOOL_TO_STR(__entry-\u003eunencrypted),\n+\t\t  __entry-\u003eproto, str_true_false(__entry-\u003eunencrypted),\n \t\t  __entry-\u003elink_id)\n );\n \n@@ -3726,7 +3726,7 @@ TRACE_EVENT(cfg80211_probe_status,\n \t),\n \tTP_printk(NETDEV_PR_FMT \" addr:%pM, cookie: %llu, acked: %s\",\n \t\t  NETDEV_PR_ARG, __entry-\u003eaddr, __entry-\u003ecookie,\n-\t\t  BOOL_TO_STR(__entry-\u003eacked))\n+\t\t  str_true_false(__entry-\u003eacked))\n );\n \n TRACE_EVENT(cfg80211_cqm_pktloss_notify,\n@@ -3769,7 +3769,7 @@ TRACE_EVENT(cfg80211_pmksa_candidate_notify,\n \t),\n \tTP_printk(NETDEV_PR_FMT \", index:%d, bssid: %pM, pre auth: %s\",\n \t\t  NETDEV_PR_ARG, __entry-\u003eindex, __entry-\u003ebssid,\n-\t\t  BOOL_TO_STR(__entry-\u003epreauth))\n+\t\t  str_true_false(__entry-\u003epreauth))\n );\n \n TRACE_EVENT(cfg80211_report_obss_beacon,\n@@ -3848,7 +3848,7 @@ TRACE_EVENT(cfg80211_scan_done,\n \t\t}\n \t),\n \tTP_printk(\"aborted: %s, scan start (TSF): %llu, tsf_bssid: %pM\",\n-\t\t  BOOL_TO_STR(__entry-\u003eaborted),\n+\t\t  str_true_false(__entry-\u003eaborted),\n \t\t  (unsigned long long)__entry-\u003escan_start_tsf,\n \t\t  __entry-\u003etsf_bssid)\n );\n"
}

2/1 2026/06/26 16:07 agent patch-evaluator
0m Model:
gemini-3.1-pro-preview

Args:
null

Results:
{
  "EnableConfigs": null,
  "FocusSymbols": [],
  "Reasoning": "The patch only replaces a custom BOOL_TO_STR macro with the standard str_true_false helper in tracepoints. This is a purely decorative change that does not alter any functional execution flow.",
  "WorthFuzzing": false
}

Instruction:
You are an expert Linux kernel maintainer.
Your job is to review a provided patch series and determine
if it makes functional changes to the kernel that should be fuzzed.

IMPORTANT: The changes have ALREADY been applied and committed as the HEAD commit in
your workspace. Do NOT rely on your internal knowledge of the kernel. You must actively
use your code access tools to examine the actual source code and confirm any assumptions.

Return WorthFuzzing=false if the patch only contains:
- Modifications to Documentation/, Kconfig files, or code comments.
- Purely decorative changes, such as logging (e.g., pr_err, printk) or tracepoints.
- Changes to numeric constants or macros that do not functionally alter execution flow.
- Code paths that are impossible to reach in virtualized environments like GCE or QEMU,
even when utilizing software-emulated hardware (e.g., usb gadget, mac80211_hwsim).

If it modifies reachable core kernel logic, drivers, or architectures, use your code search
tools to verify the code can be executed, then return WorthFuzzing=true.

When returning WorthFuzzing=true, you MUST ALSO:
1. Extract any specific kernel functions that should be heavily fuzzed into FocusSymbols.
   Avoid listing generic hot-path functions to prevent skewed test distributions.
2. Identify any specific CONFIG_ options required to properly test this new/modified feature.
   Go and look into the Kconfig files and check for ifdefs around the code, do not make assumptions.
   Do not list too generic configs (we already have them enabled). Only list those that
   specifically cover the modified code. List them in the EnableConfigs output array,
   and DO NOT add a 'CONFIG_' prefix (e.g., return "NET_IPV4" instead of "CONFIG_NET_IPV4").
Prefer calling several tools at the same time to save round-trips.


Use set-results tool to provide results of the analysis.
It must be called exactly once before the final reply.
Ignore results of this tool.

Prompt:
For your convenience, here is the diff of the changes:
commit 91f6ef0f31abb26bf36c5a07de4491de7d3afa34
Author: syz-cluster <triage@syzkaller.com>
Date:   Fri Jun 26 16:07:14 2026 +0000

    syz-cluster: applied patch under review

diff --git a/net/wireless/trace.h b/net/wireless/trace.h
index 94944f2a39a4d6..befab459852ad0 100644
--- a/net/wireless/trace.h
+++ b/net/wireless/trace.h
@@ -14,6 +14,7 @@
 
 #include <linux/rtnetlink.h>
 #include <linux/etherdevice.h>
+#include <linux/string_choices.h>
 #include <net/cfg80211.h>
 #include "core.h"
 
@@ -228,7 +229,6 @@
 		__entry->plink_state = sinfo->plink_state;	       \
 	} while (0)
 
-#define BOOL_TO_STR(bo) (bo) ? "true" : "false"
 
 #define QOS_MAP_ENTRY __field(u8, num_des)			\
 		      __array(u8, dscp_exception,		\
@@ -578,7 +578,7 @@ DECLARE_EVENT_CLASS(key_handle,
 	TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", link_id: %d, "
 		  "key_index: %u, pairwise: %s, mac addr: %pM",
 		  WIPHY_PR_ARG, WDEV_PR_ARG, __entry->link_id,
-		  __entry->key_index, BOOL_TO_STR(__entry->pairwise),
+		  __entry->key_index, str_true_false(__entry->pairwise),
 		  __entry->mac_addr)
 );
 
@@ -621,7 +621,7 @@ TRACE_EVENT(rdev_add_key,
 		  "mac addr: %pM",
 		  WIPHY_PR_ARG, WDEV_PR_ARG, __entry->link_id,
 		  __entry->key_index, __entry->mode,
-		  BOOL_TO_STR(__entry->pairwise), __entry->mac_addr)
+		  str_true_false(__entry->pairwise), __entry->mac_addr)
 );
 
 TRACE_EVENT(rdev_set_default_key,
@@ -647,8 +647,8 @@ TRACE_EVENT(rdev_set_default_key,
 	TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", link_id: %d, "
 		  "key index: %u, unicast: %s, multicast: %s",
 		  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->link_id,
-		  __entry->key_index, BOOL_TO_STR(__entry->unicast),
-		  BOOL_TO_STR(__entry->multicast))
+		  __entry->key_index, str_true_false(__entry->unicast),
+		  str_true_false(__entry->multicast))
 );
 
 TRACE_EVENT(rdev_set_default_mgmt_key,
@@ -733,7 +733,7 @@ TRACE_EVENT(rdev_start_ap,
 		  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->ssid, CHAN_DEF_PR_ARG,
 		  __entry->beacon_interval, __entry->dtim_period,
 		  __entry->hidden_ssid, __entry->wpa_ver,
-		  BOOL_TO_STR(__entry->privacy), __entry->auth_type,
+		  str_true_false(__entry->privacy), __entry->auth_type,
 		  __entry->inactivity_timeout, __entry->link_id)
 );
 
@@ -1469,7 +1469,7 @@ TRACE_EVENT(rdev_assoc,
 	TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", bssid: %pM"
 		  ", previous bssid: %pM, use mfp: %s, flags: 0x%x",
 		  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->bssid,
-		  __entry->prev_bssid, BOOL_TO_STR(__entry->use_mfp),
+		  __entry->prev_bssid, str_true_false(__entry->use_mfp),
 		  __entry->flags)
 );
 
@@ -1518,7 +1518,7 @@ TRACE_EVENT(rdev_disassoc,
 		  ", reason: %u, local state change: %s",
 		  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->bssid,
 		  __entry->reason_code,
-		  BOOL_TO_STR(__entry->local_state_change))
+		  str_true_false(__entry->local_state_change))
 );
 
 TRACE_EVENT(rdev_mgmt_tx_cancel_wait,
@@ -1591,7 +1591,7 @@ TRACE_EVENT(rdev_connect,
 		  ", ssid: %s, auth type: %d, privacy: %s, wpa versions: %u, "
 		  "flags: 0x%x, previous bssid: %pM",
 		  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->bssid, __entry->ssid,
-		  __entry->auth_type, BOOL_TO_STR(__entry->privacy),
+		  __entry->auth_type, str_true_false(__entry->privacy),
 		  __entry->wpa_versions, __entry->flags, __entry->prev_bssid)
 );
 
@@ -2033,7 +2033,7 @@ TRACE_EVENT(rdev_tdls_mgmt,
 		  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->peer,
 		  __entry->link_id, __entry->action_code, __entry->dialog_token,
 		  __entry->status_code, __entry->peer_capability,
-		  BOOL_TO_STR(__entry->initiator),
+		  str_true_false(__entry->initiator),
 		  ((u8 *)__get_dynamic_array(buf))[0])
 );
 
@@ -2246,9 +2246,9 @@ TRACE_EVENT(rdev_mgmt_tx,
 	TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", " CHAN_PR_FMT ", offchan: %s,"
 		  " wait: %u, no cck: %s, dont wait for ack: %s",
 		  WIPHY_PR_ARG, WDEV_PR_ARG, CHAN_PR_ARG,
-		  BOOL_TO_STR(__entry->offchan), __entry->wait,
-		  BOOL_TO_STR(__entry->no_cck),
-		  BOOL_TO_STR(__entry->dont_wait_for_ack))
+		  str_true_false(__entry->offchan), __entry->wait,
+		  str_true_false(__entry->no_cck),
+		  str_true_false(__entry->dont_wait_for_ack))
 );
 
 TRACE_EVENT(rdev_tx_control_port,
@@ -2276,7 +2276,7 @@ TRACE_EVENT(rdev_tx_control_port,
 		  " proto: 0x%x, unencrypted: %s, link: %d",
 		  WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->dest,
 		  be16_to_cpu(__entry->proto),
-		  BOOL_TO_STR(__entry->unencrypted),
+		  str_true_false(__entry->unencrypted),
 		  __entry->link_id)
 );
 
@@ -2894,7 +2894,7 @@ TRACE_EVENT(rdev_set_multicast_to_unicast,
 	),
 	TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", unicast: %s",
 		  WIPHY_PR_ARG, NETDEV_PR_ARG,
-		  BOOL_TO_STR(__entry->enabled))
+		  str_true_false(__entry->enabled))
 );
 
 DEFINE_EVENT(wiphy_wdev_evt, rdev_get_txq_stats,
@@ -3225,7 +3225,7 @@ TRACE_EVENT(cfg80211_return_bool,
 	TP_fast_assign(
 		__entry->ret = ret;
 	),
-	TP_printk("returned %s", BOOL_TO_STR(__entry->ret))
+	TP_printk("returned %s", str_true_false(__entry->ret))
 );
 
 DECLARE_EVENT_CLASS(cfg80211_netdev_mac_evt,
@@ -3500,7 +3500,7 @@ TRACE_EVENT(cfg80211_mgmt_tx_status,
 		__entry->ack = ack;
 	),
 	TP_printk(WDEV_PR_FMT", cookie: %llu, ack: %s",
-		  WDEV_PR_ARG, __entry->cookie, BOOL_TO_STR(__entry->ack))
+		  WDEV_PR_ARG, __entry->cookie, str_true_false(__entry->ack))
 );
 
 TRACE_EVENT(cfg80211_control_port_tx_status,
@@ -3517,7 +3517,7 @@ TRACE_EVENT(cfg80211_control_port_tx_status,
 		__entry->ack = ack;
 	),
 	TP_printk(WDEV_PR_FMT", cookie: %llu, ack: %s",
-		  WDEV_PR_ARG, __entry->cookie, BOOL_TO_STR(__entry->ack))
+		  WDEV_PR_ARG, __entry->cookie, str_true_false(__entry->ack))
 );
 
 TRACE_EVENT(cfg80211_rx_control_port,
@@ -3542,7 +3542,7 @@ TRACE_EVENT(cfg80211_rx_control_port,
 	),
 	TP_printk(NETDEV_PR_FMT ", len=%d, %pM, proto: 0x%x, unencrypted: %s, link: %d",
 		  NETDEV_PR_ARG, __entry->len, __entry->from,
-		  __entry->proto, BOOL_TO_STR(__entry->unencrypted),
+		  __entry->proto, str_true_false(__entry->unencrypted),
 		  __entry->link_id)
 );
 
@@ -3726,7 +3726,7 @@ TRACE_EVENT(cfg80211_probe_status,
 	),
 	TP_printk(NETDEV_PR_FMT " addr:%pM, cookie: %llu, acked: %s",
 		  NETDEV_PR_ARG, __entry->addr, __entry->cookie,
-		  BOOL_TO_STR(__entry->acked))
+		  str_true_false(__entry->acked))
 );
 
 TRACE_EVENT(cfg80211_cqm_pktloss_notify,
@@ -3769,7 +3769,7 @@ TRACE_EVENT(cfg80211_pmksa_candidate_notify,
 	),
 	TP_printk(NETDEV_PR_FMT ", index:%d, bssid: %pM, pre auth: %s",
 		  NETDEV_PR_ARG, __entry->index, __entry->bssid,
-		  BOOL_TO_STR(__entry->preauth))
+		  str_true_false(__entry->preauth))
 );
 
 TRACE_EVENT(cfg80211_report_obss_beacon,
@@ -3848,7 +3848,7 @@ TRACE_EVENT(cfg80211_scan_done,
 		}
 	),
 	TP_printk("aborted: %s, scan start (TSF): %llu, tsf_bssid: %pM",
-		  BOOL_TO_STR(__entry->aborted),
+		  str_true_false(__entry->aborted),
 		  (unsigned long long)__entry->scan_start_tsf,
 		  __entry->tsf_bssid)
 );

3/2 2026/06/26 16:07 llm patch-evaluator
0m Model:
gemini-3.1-pro-preview

Args:
null

Results:
null

Tokens:
							input: 4749
							output: 71
							thoughts: 175
						

Thoughts:
**Analyzing a Tracepoint Formatting Change**

Okay, so I've got this patch here that’s making a cosmetic change in `net/wireless/trace.h`. It's replacing the old `BOOL_TO_STR` macro with the `str_true_false` function from `<linux/string_choices.h>`.  My immediate thought is that this is purely a change in how tracepoints are formatted. It doesn't affect the actual execution path of the code in any way.

To be absolutely sure, I’m going to quickly glance over the diff. Ah, yes, just as I suspected! It's a straight swap: the macro is out, the function is in, and it's solely about how "true" or "false" is represented in the tracepoint output.

```diff
-#define BOOL_TO_STR(bo) (bo) ? "true" : "false"
...
-		  __entry->key_index, BOOL_TO_STR(__entry->pairwise),
+		  __entry->key_index, str_true_false(__entry->pairwise),
```

Confirmed. This is definitely a formatting change. There's no risk of introducing new bugs or influencing the program's behavior that would be of interest for fuzzing. Given my expertise, I’m confident in returning `WorthFuzzing=false` for this.



4/2 2026/06/26 16:07 tool set-results
0m Args:
{
  "EnableConfigs": [],
  "FocusSymbols": [],
  "Reasoning": "The patch only replaces a custom BOOL_TO_STR macro with the standard str_true_false helper in tracepoints. This is a purely decorative change that does not alter any functional execution flow.",
  "WorthFuzzing": false
}

Results:
{
  "EnableConfigs": null,
  "FocusSymbols": [],
  "Reasoning": "The patch only replaces a custom BOOL_TO_STR macro with the standard str_true_false helper in tracepoints. This is a purely decorative change that does not alter any functional execution flow.",
  "WorthFuzzing": false
}

LLM Calls Summary:
Total Calls Total Tokens Avg Tokens Total Duration (Seconds) Avg Duration (Seconds)
Tool Calls Summary:
Total Calls Total Duration (Seconds) Avg Duration (Seconds)