#ifndef CYGONCE_KERNEL_BITMAP_HXX #define CYGONCE_KERNEL_BITMAP_HXX //========================================================================== // // bitmap.hxx // // Bitmap scheduler class declaration(s) // //========================================================================== // ####ECOSGPLCOPYRIGHTBEGIN#### // ------------------------------------------- // This file is part of eCos, the Embedded Configurable Operating System. // Copyright (C) 1998, 1999, 2000, 2001, 2002, 2006 Free Software Foundation, Inc. // // eCos is free software; you can redistribute it and/or modify it under // the terms of the GNU General Public License as published by the Free // Software Foundation; either version 2 or (at your option) any later // version. // // eCos is distributed in the hope that it will be useful, but WITHOUT // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License // for more details. // // You should have received a copy of the GNU General Public License // along with eCos; if not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // // As a special exception, if other files instantiate templates or use // macros or inline functions from this file, or you compile this file // and link it with other works to produce a work based on this file, // this file does not by itself cause the resulting work to be covered by // the GNU General Public License. However the source code for this file // must still be made available in accordance with section (3) of the GNU // General Public License v2. // // This exception does not invalidate any other reasons why a work based // on this file might be covered by the GNU General Public License. // ------------------------------------------- // ####ECOSGPLCOPYRIGHTEND#### //========================================================================== //#####DESCRIPTIONBEGIN#### // // Author(s): nickg // Contributors: nickg // Date: 1997-09-10 // Purpose: Define bitmap scheduler implementation // Description: The classes defined here are used as base classes // by the common classes that define schedulers and thread // things. // Usage: Included according to configuration by // // //####DESCRIPTIONEND#### // //========================================================================== #include // ------------------------------------------------------------------------- // The macro CYGNUM_KERNEL_SCHED_BITMAP_SIZE contains the number of bits // that the scheduler bitmap should contain. It is derived from the number // of threads that the system is allowed to use during configuration. #ifndef CYGNUM_KERNEL_SCHED_BITMAP_SIZE #define CYGNUM_KERNEL_SCHED_BITMAP_SIZE 32 #endif #if CYGNUM_KERNEL_SCHED_BITMAP_SIZE <= 8 typedef cyg_ucount8 cyg_sched_bitmap; #elif CYGNUM_KERNEL_SCHED_BITMAP_SIZE <= 16 typedef cyg_ucount16 cyg_sched_bitmap; #elif CYGNUM_KERNEL_SCHED_BITMAP_SIZE <= 32 typedef cyg_ucount32 cyg_sched_bitmap; #else #error Bitmaps greater than 32 bits not currently allowed #endif // ------------------------------------------------------------------------- // Customize the scheduler #define CYGIMP_THREAD_PRIORITY 1 #define CYG_THREAD_MIN_PRIORITY (CYGNUM_KERNEL_SCHED_BITMAP_SIZE-1) #define CYG_THREAD_MAX_PRIORITY 0 // set default scheduling info value for thread constructors. #define CYG_SCHED_DEFAULT_INFO CYG_THREAD_MAX_PRIORITY // ------------------------------------------------------------------------- // This class contains the implementation details of the scheduler, and // provides a standard API for accessing it. class Cyg_Scheduler_Implementation : public Cyg_Scheduler_Base { friend class Cyg_ThreadQueue_Implementation; friend class Cyg_SchedThread_Implementation; cyg_sched_bitmap run_queue; Cyg_Thread *thread_table[CYGNUM_KERNEL_SCHED_BITMAP_SIZE]; protected: Cyg_Scheduler_Implementation(); // Constructor // The following functions provide the scheduler implementation // interface to the Cyg_Scheduler class. These are protected // so that only the scheduler can call them. // choose a new thread Cyg_Thread *schedule(); // make thread schedulable void add_thread(Cyg_Thread *thread); // make thread un-schedulable void rem_thread(Cyg_Thread *thread); // register thread with scheduler void register_thread(Cyg_Thread *thread); // deregister thread void deregister_thread(Cyg_Thread *thread); // Test the given priority for uniqueness cyg_bool unique( cyg_priority priority); public: void set_idle_thread( Cyg_Thread *thread, HAL_SMP_CPU_TYPE cpu ); }; // ------------------------------------------------------------------------- // Scheduler thread implementation. // This class provides the implementation of the scheduler specific parts // of each thread. class Cyg_SchedThread_Implementation { friend class Cyg_Scheduler_Implementation; friend class Cyg_ThreadQueue_Implementation; protected: cyg_priority priority; // current thread priority Cyg_SchedThread_Implementation(CYG_ADDRWORD sched_info); void yield(); // Yield CPU to next thread // These are not applicable in a bitmap scheduler; placeholders: inline void rotate_queue( cyg_priority pri ) { }; inline void to_queue_head( void ) { }; inline void timeslice_save() {}; inline void timeslice_restore() {}; inline void timeslice_reset() {}; }; // ------------------------------------------------------------------------- // Thread queue implementation. // This class provides the (scheduler specific) implementation of the // thread queue class. class Cyg_ThreadQueue_Implementation { cyg_sched_bitmap wait_queue; protected: // API used by Cyg_ThreadQueue Cyg_ThreadQueue_Implementation(); // Constructor // Add thread to queue void enqueue(Cyg_Thread *thread); // return first thread on queue Cyg_Thread *highpri(); // remove first thread on queue Cyg_Thread *dequeue(); // remove specified thread from queue void remove(Cyg_Thread *thread); // test if queue is empty cyg_bool empty(); }; inline cyg_bool Cyg_ThreadQueue_Implementation::empty() { return wait_queue == 0; } // ------------------------------------------------------------------------- #endif // ifndef CYGONCE_KERNEL_BITMAP_HXX // EOF bitmap.hxx