qurt_stubs.c 4.15 KB
/****************************************************************************
 *
 *   Copyright (C) 2015 Mark Charlebois. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 * 3. Neither the name PX4 nor the names of its contributors may be
 *    used to endorse or promote products derived from this software
 *    without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 *
 ****************************************************************************/
#include <px4_platform_common/log.h>
#include <semaphore.h>

void block_indefinite(void);
void _Read_uleb(void);
void _Parse_fde_instr(void);
void _Parse_csd(void);
void _Valbytes(void);
void _Get_eh_data(void);
void _Parse_lsda(void);
void __cxa_guard_release(void);
void _Read_enc_ptr(void);
void _Read_sleb(void);
void __cxa_guard_acquire(void);
void __cxa_pure_virtual(void);

void block_indefinite(void)
{
	sem_t forever;
	sem_init(&forever, 0, 0);
	sem_wait(&forever);
}

void _Read_uleb(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void _Parse_fde_instr(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void _Parse_csd(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void _Valbytes(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void _Get_eh_data(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void _Parse_lsda(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void __cxa_guard_release(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void _Read_enc_ptr(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void _Read_sleb(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void __cxa_guard_acquire(void)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

void __cxa_pure_virtual()
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
}

float _Stof(const char *p0, char **p1, long p2)
{
	PX4_WARN("Error: Calling unresolved symbol stub[%s]", __FUNCTION__);
	block_indefinite();
	return 0;
}

void *bsearch(const void *key, const void *ptr, size_t count, size_t size, int (*comp)(const void *, const void *))
{
	const char *first = (const char *)ptr;

	while (count > 1) {
		size_t m = count / 2;
		const char *middle_element = first + m * size;
		int cmp_res = comp(middle_element, key);

		if (cmp_res > 0) {
			count = m;

		} else if (cmp_res == 0) {
			return (void *)middle_element;

		} else {
			first = middle_element + size;
			count = count - m - 1;
		}
	}

	if (count && comp(first, key) == 0) {
		return (void *)first;
	}

	return NULL;
}