source: rtems/cpukit/score/src/schedulercbsreleasejob.c @ 1506658c

5
Last change on this file since 1506658c was 900d337f, checked in by Sebastian Huber <sebastian.huber@…>, on 05/05/15 at 11:05:54

score: Rework _Thread_Change_priority()

Move the writes to Thread_Control::current_priority and
Thread_Control::real_priority into _Thread_Change_priority() under the
protection of the thread lock. Add a filter function to
_Thread_Change_priority() to enable specialized variants.

Avoid race conditions during a thread priority restore with the new
Thread_Control::priority_restore_hint for an important average case
optimizations used by priority inheritance mutexes.

Update #2273.

  • Property mode set to 100644
File size: 1.5 KB
Line 
1/**
2 * @file
3 *
4 * @brief Scheduler CBS Release Job
5 *
6 * @ingroup ScoreScheduler
7 */
8
9/*
10 *  Copyright (C) 2011 Petr Benes.
11 *  Copyright (C) 2011 On-Line Applications Research Corporation (OAR).
12 *
13 *  The license and distribution terms for this file may be
14 *  found in the file LICENSE in this distribution or at
15 *  http://www.rtems.org/license/LICENSE.
16 */
17
18#if HAVE_CONFIG_H
19#include "config.h"
20#endif
21
22#include <rtems/score/schedulercbsimpl.h>
23#include <rtems/score/threadimpl.h>
24#include <rtems/score/watchdogimpl.h>
25
26void _Scheduler_CBS_Release_job(
27  const Scheduler_Control *scheduler,
28  Thread_Control          *the_thread,
29  uint32_t                 deadline
30)
31{
32  Scheduler_CBS_Node   *node = _Scheduler_CBS_Thread_get_node( the_thread );
33  Scheduler_CBS_Server *serv_info = node->cbs_server;
34  Priority_Control      new_priority;
35  Priority_Control      unused;
36
37  if (deadline) {
38    /* Initializing or shifting deadline. */
39    if (serv_info)
40      new_priority = (_Watchdog_Ticks_since_boot + serv_info->parameters.deadline)
41        & ~SCHEDULER_EDF_PRIO_MSB;
42    else
43      new_priority = (_Watchdog_Ticks_since_boot + deadline)
44        & ~SCHEDULER_EDF_PRIO_MSB;
45  }
46  else {
47    /* Switch back to background priority. */
48    new_priority = the_thread->Start.initial_priority;
49  }
50
51  /* Budget replenishment for the next job. */
52  if (serv_info)
53    the_thread->cpu_time_budget = serv_info->parameters.budget;
54
55  _Thread_Set_priority( the_thread, new_priority, &unused, true );
56}
Note: See TracBrowser for help on using the repository browser.