Commit 601455da authored by Bhaumik Bhatt's avatar Bhaumik Bhatt Committed by Greg Kroah-Hartman

bus: mhi: core: Introduce counters to track MHI device state transitions

Use counters to track MHI device state transitions such as those
to M0, M2, or M3 states. This can help in better debug, allowing
the user to see the number of transitions to a certain MHI state
when queried using debugfs entries or via other mechanisms.
Reviewed-by: default avatarManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Signed-off-by: default avatarBhaumik Bhatt <bbhatt@codeaurora.org>
Signed-off-by: default avatarManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Link: https://lore.kernel.org/r/20200929175218.8178-9-manivannan.sadhasivam@linaro.orgSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent a6c1fff8
...@@ -256,6 +256,7 @@ int mhi_pm_m0_transition(struct mhi_controller *mhi_cntrl) ...@@ -256,6 +256,7 @@ int mhi_pm_m0_transition(struct mhi_controller *mhi_cntrl)
dev_err(dev, "Unable to transition to M0 state\n"); dev_err(dev, "Unable to transition to M0 state\n");
return -EIO; return -EIO;
} }
mhi_cntrl->M0++;
/* Wake up the device */ /* Wake up the device */
read_lock_bh(&mhi_cntrl->pm_lock); read_lock_bh(&mhi_cntrl->pm_lock);
...@@ -326,6 +327,8 @@ void mhi_pm_m1_transition(struct mhi_controller *mhi_cntrl) ...@@ -326,6 +327,8 @@ void mhi_pm_m1_transition(struct mhi_controller *mhi_cntrl)
mhi_cntrl->dev_state = MHI_STATE_M2; mhi_cntrl->dev_state = MHI_STATE_M2;
write_unlock_irq(&mhi_cntrl->pm_lock); write_unlock_irq(&mhi_cntrl->pm_lock);
mhi_cntrl->M2++;
wake_up_all(&mhi_cntrl->state_event); wake_up_all(&mhi_cntrl->state_event);
/* If there are any pending resources, exit M2 immediately */ /* If there are any pending resources, exit M2 immediately */
...@@ -362,6 +365,7 @@ int mhi_pm_m3_transition(struct mhi_controller *mhi_cntrl) ...@@ -362,6 +365,7 @@ int mhi_pm_m3_transition(struct mhi_controller *mhi_cntrl)
return -EIO; return -EIO;
} }
mhi_cntrl->M3++;
wake_up_all(&mhi_cntrl->state_event); wake_up_all(&mhi_cntrl->state_event);
return 0; return 0;
......
...@@ -328,6 +328,7 @@ struct mhi_controller_config { ...@@ -328,6 +328,7 @@ struct mhi_controller_config {
* @dev_state: MHI device state * @dev_state: MHI device state
* @dev_wake: Device wakeup count * @dev_wake: Device wakeup count
* @pending_pkts: Pending packets for the controller * @pending_pkts: Pending packets for the controller
* @M0, M2, M3: Counters to track number of device MHI state changes
* @transition_list: List of MHI state transitions * @transition_list: List of MHI state transitions
* @transition_lock: Lock for protecting MHI state transition list * @transition_lock: Lock for protecting MHI state transition list
* @wlock: Lock for protecting device wakeup * @wlock: Lock for protecting device wakeup
...@@ -407,6 +408,7 @@ struct mhi_controller { ...@@ -407,6 +408,7 @@ struct mhi_controller {
enum mhi_state dev_state; enum mhi_state dev_state;
atomic_t dev_wake; atomic_t dev_wake;
atomic_t pending_pkts; atomic_t pending_pkts;
u32 M0, M2, M3;
struct list_head transition_list; struct list_head transition_list;
spinlock_t transition_lock; spinlock_t transition_lock;
spinlock_t wlock; spinlock_t wlock;
......
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