Commit b5caf05e authored by Harald Freudenberger's avatar Harald Freudenberger Committed by Heiko Carstens

s390/ap: rework ap_scan_bus() to return true on config change

The AP scan bus function now returns true if there have
been any config changes detected. This will become
important in a follow up patch which will exploit this
hint for further actions. This also required to have
the AP scan bus timer callback reworked as the function
signature has changed to bool ap_scan_bus(void).
Signed-off-by: default avatarHarald Freudenberger <freude@linux.ibm.com>
Reviewed-by: default avatarHolger Dengler <dengler@linux.ibm.com>
Signed-off-by: default avatarHeiko Carstens <hca@linux.ibm.com>
parent 99b3126e
...@@ -104,8 +104,8 @@ debug_info_t *ap_dbf_info; ...@@ -104,8 +104,8 @@ debug_info_t *ap_dbf_info;
static atomic64_t ap_scan_bus_count; /* counter ap_scan_bus() invocations */ static atomic64_t ap_scan_bus_count; /* counter ap_scan_bus() invocations */
static int ap_scan_bus_time = AP_CONFIG_TIME; static int ap_scan_bus_time = AP_CONFIG_TIME;
static struct timer_list ap_scan_bus_timer; static struct timer_list ap_scan_bus_timer;
static void ap_scan_bus(struct work_struct *); static void ap_scan_bus_wq_callback(struct work_struct *);
static DECLARE_WORK(ap_scan_bus_work, ap_scan_bus); static DECLARE_WORK(ap_scan_bus_work, ap_scan_bus_wq_callback);
/* /*
* Tasklet & timer for AP request polling and interrupts * Tasklet & timer for AP request polling and interrupts
...@@ -2179,12 +2179,13 @@ static bool ap_config_has_new_doms(void) ...@@ -2179,12 +2179,13 @@ static bool ap_config_has_new_doms(void)
/** /**
* ap_scan_bus(): Scan the AP bus for new devices * ap_scan_bus(): Scan the AP bus for new devices
* Runs periodically, workqueue timer (ap_scan_bus_time) * Returns true if any config change has been detected
* @unused: Unused pointer. * otherwise false.
*/ */
static void ap_scan_bus(struct work_struct *unused) static bool ap_scan_bus(void)
{ {
int ap, config_changed = 0; bool config_changed;
int ap;
pr_debug(">%s\n", __func__); pr_debug(">%s\n", __func__);
...@@ -2235,11 +2236,14 @@ static void ap_scan_bus(struct work_struct *unused) ...@@ -2235,11 +2236,14 @@ static void ap_scan_bus(struct work_struct *unused)
mod_timer(&ap_scan_bus_timer, jiffies + ap_scan_bus_time * HZ); mod_timer(&ap_scan_bus_timer, jiffies + ap_scan_bus_time * HZ);
pr_debug("<%s\n", __func__); pr_debug("<%s config_changed=%d\n", __func__, config_changed);
return config_changed;
} }
/* /*
* Callback for the ap_scan_bus_timer * Callback for the ap_scan_bus_timer
* Runs periodically, workqueue timer (ap_scan_bus_time)
*/ */
static void ap_scan_bus_timer_callback(struct timer_list *unused) static void ap_scan_bus_timer_callback(struct timer_list *unused)
{ {
...@@ -2250,6 +2254,15 @@ static void ap_scan_bus_timer_callback(struct timer_list *unused) ...@@ -2250,6 +2254,15 @@ static void ap_scan_bus_timer_callback(struct timer_list *unused)
queue_work(system_long_wq, &ap_scan_bus_work); queue_work(system_long_wq, &ap_scan_bus_work);
} }
/*
* Callback for the ap_scan_bus_work
*/
static void ap_scan_bus_wq_callback(struct work_struct *unused)
{
/* now finally do the AP bus scan */
ap_scan_bus();
}
static int __init ap_debug_init(void) static int __init ap_debug_init(void)
{ {
ap_dbf_info = debug_register("ap", 2, 1, ap_dbf_info = debug_register("ap", 2, 1,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment