thread.hpp
Go to the documentation of this file.
00001 /*
00002  *  RPLIDAR SDK
00003  *
00004  *  Copyright (c) 2009 - 2014 RoboPeak Team
00005  *  http://www.robopeak.com
00006  *  Copyright (c) 2014 - 2018 Shanghai Slamtec Co., Ltd.
00007  *  http://www.slamtec.com
00008  *
00009  */
00010 /*
00011  * Redistribution and use in source and binary forms, with or without
00012  * modification, are permitted provided that the following conditions are met:
00013  *
00014  * 1. Redistributions of source code must retain the above copyright notice,
00015  *    this list of conditions and the following disclaimer.
00016  *
00017  * 2. Redistributions in binary form must reproduce the above copyright notice,
00018  *    this list of conditions and the following disclaimer in the documentation
00019  *    and/or other materials provided with the distribution.
00020  *
00021  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00022  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
00023  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
00024  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
00025  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
00026  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
00027  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
00028  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
00029  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
00030  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
00031  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00032  *
00033  */
00034 
00035 #include "arch/linux/arch_linux.h"
00036 
00037 #include <sched.h>
00038 
00039 namespace rp{ namespace hal{
00040 
00041 Thread Thread::create(thread_proc_t proc, void * data)
00042 {
00043     Thread newborn(proc, data);
00044     
00045     // tricky code, we assume pthread_t is not a structure but a word size value
00046     assert( sizeof(newborn._handle) >= sizeof(pthread_t));
00047 
00048     pthread_create((pthread_t *)&newborn._handle, NULL, (void * (*)(void *))proc, data);
00049 
00050     return newborn;
00051 }
00052 
00053 u_result Thread::terminate()
00054 {
00055     if (!this->_handle) return RESULT_OK;
00056     
00057     return pthread_cancel((pthread_t)this->_handle)==0?RESULT_OK:RESULT_OPERATION_FAIL;
00058 }
00059 
00060 u_result Thread::setPriority( priority_val_t p)
00061 {
00062     if (!this->_handle) return RESULT_OPERATION_FAIL;
00063     
00064     // check whether current schedule policy supports priority levels
00065     
00066     int current_policy;
00067     struct sched_param current_param;
00068     int ans;
00069     if (pthread_getschedparam( (pthread_t) this->_handle, &current_policy, &current_param))
00070     {
00071         // cannot retreieve values
00072         return RESULT_OPERATION_FAIL;
00073     }   
00074 
00075     //int pthread_priority = 0 ;
00076 
00077     switch(p)
00078     {
00079     case PRIORITY_REALTIME:
00080         //pthread_priority = pthread_priority_max;
00081         current_policy = SCHED_RR;
00082         break;
00083     case PRIORITY_HIGH:
00084         //pthread_priority = (pthread_priority_max + pthread_priority_min)/2;
00085         current_policy = SCHED_RR;
00086         break;
00087     case PRIORITY_NORMAL:
00088     case PRIORITY_LOW:
00089     case PRIORITY_IDLE:
00090         //pthread_priority = 0;
00091         current_policy = SCHED_OTHER;
00092         break;
00093     }
00094 
00095     current_param.__sched_priority = current_policy;
00096     if ( (ans = pthread_setschedparam( (pthread_t) this->_handle, current_policy, &current_param)) )
00097     {
00098         return RESULT_OPERATION_FAIL;
00099     }
00100     return  RESULT_OK;
00101 }
00102 
00103 Thread::priority_val_t Thread::getPriority()
00104 {
00105     if (!this->_handle) return PRIORITY_NORMAL;
00106 
00107     int current_policy;
00108     struct sched_param current_param;
00109     if (pthread_getschedparam( (pthread_t) this->_handle, &current_policy, &current_param))
00110     {
00111         // cannot retreieve values
00112         return PRIORITY_NORMAL;
00113     }   
00114 
00115     int pthread_priority_max = sched_get_priority_max(SCHED_RR);
00116     int pthread_priority_min = sched_get_priority_min(SCHED_RR);
00117 
00118     if (current_param.__sched_priority ==(pthread_priority_max ))
00119     {
00120         return PRIORITY_REALTIME;
00121     }
00122     if (current_param.__sched_priority >=(pthread_priority_max + pthread_priority_min)/2)
00123     {
00124         return PRIORITY_HIGH;
00125     }
00126     return PRIORITY_NORMAL;
00127 }
00128 
00129 u_result Thread::join(unsigned long timeout)
00130 {
00131     if (!this->_handle) return RESULT_OK;
00132     
00133     pthread_join((pthread_t)(this->_handle), NULL);
00134     return RESULT_OK;
00135 }
00136 
00137 }}


rplidar_ros
Author(s):
autogenerated on Mon Mar 18 2019 02:34:23