| --- a/src/drv_tapi_linux.c |
| +++ b/src/drv_tapi_linux.c |
| @@ -119,7 +119,11 @@ struct _TAPI_FD_PRIV_DATA |
| /* ============================= */ |
| /* Local Functions */ |
| /* ============================= */ |
| +#if LINUX_VERSION_CODE < KERNEL_VERSION(4,15,0) |
| static IFX_void_t TAPI_timer_call_back (IFX_ulong_t arg); |
| +#else |
| +static IFX_void_t TAPI_timer_call_back (struct timer_list *t); |
| +#endif |
| #if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,20)) |
| static IFX_void_t TAPI_tqueue (IFX_void_t *pWork); |
| #else /* for Kernel newer or equal 2.6.20 */ |
| @@ -3384,11 +3388,15 @@ Timer_ID TAPI_Create_Timer(TIMER_ENTRY p |
| pTimerData->nArgument = nArgument; |
| pTimerData->bStopped = IFX_FALSE; |
| |
| +#if (LINUX_VERSION_CODE < KERNEL_VERSION(4,15,0)) |
| init_timer(&(pTimerData->Timer_List)); |
| |
| /* set timer call back function */ |
| pTimerData->Timer_List.function = TAPI_timer_call_back; |
| pTimerData->Timer_List.data = (IFX_ulong_t) pTimerData; |
| +#else |
| + timer_setup(&(pTimerData->Timer_List), TAPI_timer_call_back, 0); |
| +#endif |
| |
| /* Initialize Timer Task */ |
| #ifdef LINUX_2_6 |
| @@ -3529,9 +3537,17 @@ static IFX_void_t TAPI_tqueue (struct wo |
| |
| \param arg Pointer to corresponding timer ID. |
| */ |
| +#if LINUX_VERSION_CODE < KERNEL_VERSION(4,15,0) |
| static IFX_void_t TAPI_timer_call_back (IFX_ulong_t arg) |
| +#else |
| +static IFX_void_t TAPI_timer_call_back (struct timer_list *t) |
| +#endif |
| { |
| +#if LINUX_VERSION_CODE < KERNEL_VERSION(4,15,0) |
| Timer_ID Timer = (Timer_ID) arg; |
| +#else |
| + Timer_ID Timer = from_timer(Timer, t, Timer_List); |
| +#endif |
| /* do the operation in process context, |
| not in interrupt context */ |
| #ifdef LINUX_2_6 |