/******************************************************************************
|
*
|
* Copyright(c) 2019 - 2020 Realtek Corporation.
|
*
|
* This program is free software; you can redistribute it and/or modify it
|
* under the terms of version 2 of the GNU General Public License as
|
* published by the Free Software Foundation.
|
*
|
* This program 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.
|
*
|
*****************************************************************************/
|
#ifndef _PLTFM_OPS_MACOS_H_
|
#define _PLTFM_OPS_MACOS_H_
|
|
static __inline char *_os_strsep(char **s, const char *ct)
|
{
|
return NULL;
|
}
|
static __inline int _os_sscanf(const char *buf, const char *fmt, ...)
|
{
|
return 0;
|
}
|
static __inline int _os_strcmp(const char *s1, const char *s2)
|
{
|
return 0;
|
}
|
static __inline int _os_strncmp(const char *s1, const char *s2, size_t n)
|
{
|
return 0;
|
}
|
static __inline char *_os_strcpy(char *dest, const char *src)
|
{
|
return NULL;
|
}
|
static inline char *_os_strncpy(char *dest, const char *src, size_t n)
|
{
|
return NULL;
|
}
|
static __inline char *_os_strchr(const char *s, int c)
|
{
|
while (*s != (char)c)
|
if (*s++ == '\0')
|
return NULL;
|
return (char *)s;
|
}
|
static __inline int _os_snprintf(char *str, size_t size, const char *format, ...)
|
{
|
return 0;
|
}
|
|
static __inline u32 _os_strlen(u8 *buf)
|
{
|
return 0;
|
}
|
static __inline void _os_delay_ms(void *h, u32 ms)
|
{
|
}
|
static __inline void _os_delay_us(void *h, u32 us)
|
{
|
}
|
static __inline void _os_sleep_ms(void *h, u32 ms)
|
{
|
}
|
static __inline void _os_sleep_us(void *h, u32 us)
|
{
|
}
|
static inline u32 _os_get_cur_time_us(void)
|
{
|
return 0;
|
}
|
static inline u32 _os_get_cur_time_ms(void)
|
{
|
return 0;
|
}
|
|
static inline u64 _os_modular64(u64 x, u64 y)
|
{
|
return x % y;
|
}
|
static inline u64 _os_division64(u64 x, u64 y)
|
{
|
return x / y;
|
}
|
|
#ifdef CONFIG_PCI_HCI
|
static inline void _os_cache_inv(void *d, u32 *bus_addr_l, u32 *bus_addr_h,
|
u32 buf_sz, u8 direction)
|
{
|
}
|
static inline void _os_cache_wback(void *d, u32 *bus_addr_l,
|
u32 *bus_addr_h, u32 buf_sz, u8 direction)
|
{
|
}
|
|
static inline void *_os_dma_pool_create(void *d, char *name, u32 wd_page_sz)
|
{
|
return NULL;
|
}
|
|
static inline void _os_dma_pool_destory(void *d, void *pool)
|
{
|
}
|
|
/* txbd, rxbd, wd */
|
static inline void *_os_shmem_alloc(void *d, void *pool, u32 *bus_addr_l,
|
u32 *bus_addr_h, u32 buf_sz,
|
u8 cache, u8 direction, void **os_rsvd)
|
{
|
return NULL;
|
}
|
static inline void _os_shmem_free(void *d, void *pool, u8 *vir_addr, u32 *bus_addr_l,
|
u32 *bus_addr_h, u32 buf_sz,
|
u8 cache, u8 direction, void *os_rsvd)
|
{
|
return NULL;
|
}
|
#endif
|
|
static inline void *_os_pkt_buf_unmap_rx(void *d, u32 bus_addr_l, u32 bus_addr_h, u32 buf_sz)
|
{
|
return NULL;
|
}
|
|
static inline void *_os_pkt_buf_map_rx(void *d, u32 *bus_addr_l, u32 *bus_addr_h,
|
u32 buf_sz, void *os_priv)
|
{
|
return NULL;
|
}
|
|
static inline void *_os_pkt_buf_alloc_rx(void *d, u32 *bus_addr_l, u32 *bus_addr_h,
|
u32 buf_sz, enum cache_addr_type cache, void **os_priv)
|
{
|
return NULL;
|
}
|
static inline u8 *_os_pkt_buf_free_rx(void *d, u8 *vir_addr, u32 bus_addr_l,
|
u32 bus_addr_h, u32 buf_sz, enum cache_addr_type cache, void *os_priv)
|
{
|
return NULL;
|
}
|
|
/* phl pre-alloc network layer buffer */
|
static inline void * _os_alloc_netbuf(void *d, u32 buf_sz, void **os_priv)
|
{
|
return NULL; // windows never do this.
|
}
|
|
/* Free netbuf for error case. (ex. drop rx-reorder packet) */
|
static inline void _os_free_netbuf(void *d, u8 *vir_addr, u32 buf_sz, void *os_priv)
|
{
|
}
|
|
/* Generate an unsigned 32-bit random number */
|
static inline u32 _os_random32(void *d)
|
{
|
return 0;
|
}
|
|
static __inline void *_os_mem_alloc(void *h, u32 buf_sz)
|
{
|
return NULL;
|
}
|
|
static __inline void _os_mem_free(void *h, void *buf, u32 buf_sz)
|
{
|
}
|
/*physically contiguous memory if the buffer will be accessed by a DMA device*/
|
static inline void *_os_kmem_alloc(void *h, u32 buf_sz)
|
{
|
return NULL;
|
}
|
|
/*physically contiguous memory if the buffer will be accessed by a DMA device*/
|
static inline void _os_kmem_free(void *h, void *buf, u32 buf_sz)
|
{
|
}
|
static __inline void _os_mem_set(void *h, void *buf, s8 value, u32 size)
|
{
|
}
|
static __inline void _os_mem_cpy(void *h, void *dest, const void *src, u32 size)
|
{
|
}
|
static __inline int _os_mem_cmp(void *h, const void *ptr1, const void *ptr2, u32 size)
|
{
|
return 0;
|
}
|
static __inline void _os_init_timer(void *h, _os_timer *timer,
|
void (*call_back_func)(void *context), void *context,
|
const char *sz_id)
|
{
|
}
|
|
static __inline void _os_set_timer(void *h, _os_timer *timer, u32 ms_delay)
|
{
|
}
|
|
static __inline void _os_cancel_timer(void *h, _os_timer *timer)
|
{
|
}
|
static inline void _os_cancel_timer_async(void *d, _os_timer *timer)
|
{
|
}
|
|
static __inline void _os_release_timer(void *h, _os_timer *timer)
|
{
|
|
}
|
static __inline void _os_mutex_init(void *h, _os_mutex *mutex)
|
{
|
}
|
|
static __inline void _os_mutex_deinit(void *h, _os_mutex *mutex)
|
{
|
}
|
|
static __inline void _os_mutex_lock(void *h, _os_mutex *mutex)
|
{
|
}
|
|
static __inline void _os_mutex_unlock(void *h, _os_mutex *mutex)
|
{
|
}
|
|
static inline void _os_sema_init(void *h, _os_sema *sema, int int_cnt)
|
{
|
}
|
|
static inline void _os_sema_free(void *h, _os_sema *sema)
|
{
|
}
|
|
static inline void _os_sema_up(void *h, _os_sema *sema)
|
{
|
}
|
|
static inline u8 _os_sema_down(void *h, _os_sema *sema)
|
{
|
return 0; //success
|
}
|
|
static __inline void _os_spinlock_init(void *d, _os_lock *plock)
|
{
|
}
|
static __inline void _os_spinlock_free(void *d, _os_lock *plock)
|
{
|
}
|
static inline void _os_spinlock(void *d, _os_lock *plock,
|
enum lock_type type, _os_spinlockfg *flags)
|
{
|
}
|
|
static inline void _os_spinunlock(void *d, _os_lock *plock,
|
enum lock_type type, _os_spinlockfg *flags)
|
{
|
}
|
|
/* event */
|
static __inline void _os_event_init(void *h, _os_event *event)
|
{
|
}
|
static __inline void _os_event_free(void *h, _os_event *event)
|
{
|
}
|
static __inline void _os_event_reset(void *h, _os_event *event)
|
{
|
}
|
static __inline void _os_event_set(void *h, _os_event *event)
|
{
|
}
|
|
/*
|
* m_sec
|
* == 0 : wait for completion
|
* > 0 : wait for timeout or completion
|
* return value
|
* 0:timeout
|
* otherwise:success
|
*/
|
static __inline int _os_event_wait(void *h, _os_event *event, u32 m_sec)
|
{
|
return 0;
|
}
|
|
static inline int _os_test_and_clear_bit(int nr, unsigned long *addr)
|
{
|
/*UNDO*/
|
return 0;
|
}
|
static inline int _os_test_and_set_bit(int nr, unsigned long *addr)
|
{
|
/*UNDO*/
|
return 1;
|
}
|
/* Atomic integer operations */
|
static __inline void _os_atomic_set(void *d, _os_atomic *v, int i)
|
{
|
}
|
|
static __inline int _os_atomic_read(void *d, _os_atomic *v)
|
{
|
return 0;
|
}
|
|
static __inline void _os_atomic_add(void *d, _os_atomic *v, int i)
|
{
|
}
|
static __inline void _os_atomic_sub(void *d, _os_atomic *v, int i)
|
{
|
}
|
|
static __inline void _os_atomic_inc(void *d, _os_atomic *v)
|
{
|
}
|
|
static __inline void _os_atomic_dec(void *d, _os_atomic *v)
|
{
|
}
|
|
static __inline int _os_atomic_add_return(void *d, _os_atomic *v, int i)
|
{
|
return 0;
|
}
|
|
static __inline int _os_atomic_sub_return(void *d, _os_atomic *v, int i)
|
{
|
return 0;
|
}
|
|
static __inline int _os_atomic_inc_return(void *d, _os_atomic *v)
|
{
|
return 0;
|
}
|
|
static __inline int _os_atomic_dec_return(void *d, _os_atomic *v)
|
{
|
return 0;
|
}
|
/*
|
static __inline bool _os_atomic_inc_unless(void *d, _os_atomic *v, int u)
|
{
|
return 0;
|
}
|
*/
|
static inline u8 _os_tasklet_init(void *drv_priv, _os_tasklet *task,
|
void (*call_back_func)(void* context), void *context)
|
{
|
return 0;
|
}
|
static inline u8 _os_tasklet_deinit(void *drv_priv, _os_tasklet *task)
|
{
|
return 0;
|
}
|
static inline u8 _os_tasklet_schedule(void *drv_priv, _os_tasklet *task)
|
{
|
return 0;
|
}
|
|
static __inline u8 _os_thread_init( void *drv_priv, _os_thread *thread,
|
int (*call_back_func)(void * context),
|
void *context,
|
const char namefmt[])
|
{
|
return RTW_PHL_STATUS_FAILURE;
|
}
|
static __inline u8 _os_thread_deinit(void *drv_priv, _os_thread *thread)
|
{
|
return RTW_PHL_STATUS_FAILURE;
|
}
|
static __inline enum rtw_phl_status _os_thread_schedule(void *drv_priv, _os_thread *thread)
|
{
|
return RTW_PHL_STATUS_FAILURE;
|
}
|
static inline void _os_thread_stop(void *drv_priv, _os_thread *thread)
|
{
|
}
|
static inline int _os_thread_check_stop(void *drv_priv, _os_thread *thread)
|
{
|
return 1;
|
}
|
static inline int _os_thread_wait_stop(void *drv_priv, _os_thread *thread)
|
{
|
return RTW_PHL_STATUS_SUCCESS;
|
}
|
|
#if 0 /* TODO */
|
static inline _os_thread _os_thread_start(int (*threadfn)(void *data),
|
void *data, const char namefmt[])
|
{
|
return 0;
|
}
|
static inline bool _os_thread_stop(_os_thread th)
|
{
|
return 0;
|
}
|
static inline void _os_thread_wait_stop(void)
|
{
|
}
|
static inline int _os_thread_check_stop(void)
|
{
|
return 0;
|
}
|
#endif
|
|
static inline u8 _os_workitem_init(void *drv_priv, _os_workitem *workitem,
|
void (*call_back_func)(void* context), void *context)
|
{
|
return 0;
|
}
|
static inline u8 _os_workitem_schedule(void *drv_priv, _os_workitem *workitem)
|
{
|
return 0;
|
}
|
static inline u8 _os_workitem_deinit(void *drv_priv, _os_workitem *workitem)
|
{
|
return 0;
|
}
|
|
/* OS handler extension */
|
static inline u8 _os_init_handler_ext(void *drv_priv,
|
void *phl_handler)
|
{
|
return RTW_PHL_STATUS_SUCCESS;
|
}
|
|
static inline u8 _os_deinit_handler_ext(void *drv_priv,
|
void *phl_handler)
|
{
|
return RTW_PHL_STATUS_SUCCESS;
|
}
|
|
/* File Operation */
|
static inline u32 _os_read_file(const char *path, u8 *buf, u32 sz)
|
{
|
/* OS Dependent API */
|
return 0;
|
}
|
|
/* Network Function */
|
#ifdef CONFIG_RTW_MIRROR_DUMP
|
static inline u32 _os_mirror_dump(u8 *hdr, u32 hdr_len, u8 *buf, u32 sz)
|
{
|
return 0;
|
}
|
#endif
|
|
#ifdef CONFIG_PCI_HCI
|
static __inline u8 _os_read8_pcie(void *h, u32 addr)
|
{
|
return 0;
|
}
|
static __inline u16 _os_read16_pcie(void *h, u32 addr)
|
{
|
return 0;
|
|
}
|
static __inline u32 _os_read32_pcie(void *h, u32 addr)
|
{
|
return 0;
|
}
|
|
static __inline u32 _os_write8_pcie(void *h, u32 addr, u8 val)
|
{
|
return 0;
|
}
|
static __inline u32 _os_write16_pcie(void *h, u32 addr, u16 val)
|
{
|
return 0;
|
}
|
static __inline u32 _os_write32_pcie(void *h, u32 addr, u32 val)
|
{
|
return 0;
|
}
|
#endif/*#ifdef CONFIG_PCI_HCI*/
|
|
#ifdef CONFIG_USB_HCI
|
static __inline u32 _os_usbctrl_vendorreq(void *h, u8 request, u16 value,
|
u16 index, void *pdata, u16 len, u8 requesttype)
|
{
|
return 0;
|
}
|
|
static inline int os_usb_tx(void *h, u8 *tx_buf_ptr,
|
u8 bulk_id, u32 len, u8 *pkt_data_buf)
|
{
|
return 1;
|
}
|
|
#endif /*CONFIG_USB_HCI*/
|
|
#ifdef CONFIG_SDIO_HCI
|
static __inline u8 _os_sdio_cmd52_r8(void *d, u32 offset)
|
{
|
return 0;
|
}
|
|
static __inline u8 _os_sdio_cmd53_r8(void *d, u32 offset)
|
{
|
return 0;
|
}
|
|
static __inline u16 _os_sdio_cmd53_r16(void *d, u32 offset)
|
{
|
return 0;
|
}
|
|
static __inline u32 _os_sdio_cmd53_r32(void *d, u32 offset)
|
{
|
return 0;
|
}
|
|
static __inline u8 _os_sdio_cmd53_rn(void *d, u32 offset, u32 size, u8 *data)
|
{
|
return 0;
|
}
|
|
static __inline u8 _os_sdio_cmd53_r(void *d, u32 offset, u32 size, u8 *data)
|
{
|
/* TODO: implement read RX FIFO */
|
return 0;
|
}
|
|
static __inline void _os_sdio_cmd52_w8(void *d, u32 offset, u8 val)
|
{
|
}
|
|
static __inline void _os_sdio_cmd53_w8(void *d, u32 offset, u8 val)
|
{
|
}
|
|
static __inline void _os_sdio_cmd53_w16(void *d, u32 offset, u16 val)
|
{
|
}
|
|
static __inline void _os_sdio_cmd53_w32(void *d, u32 offset, u32 val)
|
{
|
}
|
|
static __inline void _os_sdio_cmd53_wn(void *d, u32 offset, u32 size, u8 *data)
|
{
|
}
|
|
static __inline void _os_sdio_cmd53_w(void *d, u32 offset, u32 size, u8 *data)
|
{
|
}
|
|
static __inline u8 _os_sdio_f0_read(void *d, u32 addr, void *buf, size_t len)
|
{
|
return 0;
|
}
|
|
static __inline u8 _os_sdio_read_cia_r8(void *d, u32 addr)
|
{
|
return 0;
|
}
|
#endif /*CONFIG_SDIO_HCI*/
|
|
/* temp os dependency */
|
|
/* can delete if osdep ready */
|
|
|
#endif /*_PLTFM_OPS_MACOS_H_*/
|