Commit 9d9d2239 authored by Avi Kivity's avatar Avi Kivity Committed by Marcelo Tosatti

KVM: Simplify kvm_pit_timer

'timer_mode_mask' is unused
'tscdeadline' is unused
't_ops' only adds needless indirection
'vcpu' is unused

Remove.
Signed-off-by: default avatarAvi Kivity <avi@redhat.com>
Signed-off-by: default avatarMarcelo Tosatti <mtosatti@redhat.com>
parent 2a6eac96
...@@ -272,17 +272,6 @@ static void destroy_pit_timer(struct kvm_pit *pit) ...@@ -272,17 +272,6 @@ static void destroy_pit_timer(struct kvm_pit *pit)
flush_kthread_work(&pit->expired); flush_kthread_work(&pit->expired);
} }
static bool kpit_is_periodic(struct kvm_pit_timer *ktimer)
{
struct kvm_kpit_state *ps = container_of(ktimer, struct kvm_kpit_state,
pit_timer);
return ps->is_periodic;
}
static struct kvm_pit_timer_ops kpit_ops = {
.is_periodic = kpit_is_periodic,
};
static void pit_do_work(struct kthread_work *work) static void pit_do_work(struct kthread_work *work)
{ {
struct kvm_pit *pit = container_of(work, struct kvm_pit, expired); struct kvm_pit *pit = container_of(work, struct kvm_pit, expired);
...@@ -330,7 +319,7 @@ static enum hrtimer_restart pit_timer_fn(struct hrtimer *data) ...@@ -330,7 +319,7 @@ static enum hrtimer_restart pit_timer_fn(struct hrtimer *data)
queue_kthread_work(&pt->worker, &pt->expired); queue_kthread_work(&pt->worker, &pt->expired);
} }
if (ktimer->t_ops->is_periodic(ktimer)) { if (pt->pit_state.is_periodic) {
hrtimer_add_expires_ns(&ktimer->timer, ktimer->period); hrtimer_add_expires_ns(&ktimer->timer, ktimer->period);
return HRTIMER_RESTART; return HRTIMER_RESTART;
} else } else
...@@ -357,7 +346,6 @@ static void create_pit_timer(struct kvm *kvm, u32 val, int is_period) ...@@ -357,7 +346,6 @@ static void create_pit_timer(struct kvm *kvm, u32 val, int is_period)
ps->is_periodic = is_period; ps->is_periodic = is_period;
pt->timer.function = pit_timer_fn; pt->timer.function = pit_timer_fn;
pt->t_ops = &kpit_ops;
pt->kvm = ps->pit->kvm; pt->kvm = ps->pit->kvm;
atomic_set(&pt->pending, 0); atomic_set(&pt->pending, 0);
......
...@@ -24,17 +24,9 @@ struct kvm_kpit_channel_state { ...@@ -24,17 +24,9 @@ struct kvm_kpit_channel_state {
struct kvm_pit_timer { struct kvm_pit_timer {
struct hrtimer timer; struct hrtimer timer;
s64 period; /* unit: ns */ s64 period; /* unit: ns */
u32 timer_mode_mask;
u64 tscdeadline;
atomic_t pending; /* accumulated triggered timers */ atomic_t pending; /* accumulated triggered timers */
bool reinject; bool reinject;
struct kvm_pit_timer_ops *t_ops;
struct kvm *kvm; struct kvm *kvm;
struct kvm_vcpu *vcpu;
};
struct kvm_pit_timer_ops {
bool (*is_periodic)(struct kvm_pit_timer *);
}; };
struct kvm_kpit_state { struct kvm_kpit_state {
......
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