mirror of
https://github.com/projectacrn/acrn-hypervisor.git
synced 2025-08-12 13:32:31 +00:00
Now, need_reschedule will test_and_clear the bit NEED_RESCHEDULE in schedule context, then call schedule. It is not a exact match with the name. This patch move the flag clearing into scheudle, and need_reschedule just check and return. Tracked-On: #1821 Signed-off-by: Shuo A Liu <shuo.a.liu@intel.com> Reviewed-by: Yin Fengwei <fengwei.yin@intel.com>
44 lines
993 B
C
44 lines
993 B
C
/*
|
|
* Copyright (C) 2018 Intel Corporation. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#ifndef SCHEDULE_H
|
|
#define SCHEDULE_H
|
|
|
|
#define NEED_RESCHEDULE (1U)
|
|
#define NEED_OFFLINE (2U)
|
|
|
|
struct sched_context {
|
|
spinlock_t runqueue_lock;
|
|
struct list_head runqueue;
|
|
uint64_t flags;
|
|
struct acrn_vcpu *curr_vcpu;
|
|
spinlock_t scheduler_lock;
|
|
};
|
|
|
|
void init_scheduler(void);
|
|
void get_schedule_lock(uint16_t pcpu_id);
|
|
void release_schedule_lock(uint16_t pcpu_id);
|
|
|
|
void set_pcpu_used(uint16_t pcpu_id);
|
|
uint16_t allocate_pcpu(void);
|
|
void free_pcpu(uint16_t pcpu_id);
|
|
|
|
void add_vcpu_to_runqueue(struct acrn_vcpu *vcpu);
|
|
void remove_vcpu_from_runqueue(struct acrn_vcpu *vcpu);
|
|
|
|
void default_idle(void);
|
|
|
|
void make_reschedule_request(const struct acrn_vcpu *vcpu);
|
|
bool need_reschedule(uint16_t pcpu_id);
|
|
void make_pcpu_offline(uint16_t pcpu_id);
|
|
int32_t need_offline(uint16_t pcpu_id);
|
|
|
|
void schedule(void);
|
|
|
|
void vcpu_thread(struct acrn_vcpu *vcpu);
|
|
#endif /* SCHEDULE_H */
|
|
|