/* * Author: Thomas Ingleby * Copyright (c) 2014 Intel Corporation. * * SPDX-License-Identifier: MIT */ #pragma once #ifdef __cplusplus extern "C" { #endif #include #include #include "common.h" #include "mraa_internal_types.h" #include "mraa_adv_func.h" #include "mraa_lang_func.h" extern mraa_board_t* plat; extern char* platform_name; #if !defined(PERIPHERALMAN) extern mraa_iio_info_t* plat_iio; #endif extern mraa_lang_func_t* lang_func; /** * Takes in pin information and sets up the multiplexors. * * @param meta * @return mraa result type indicating success of actions. */ mraa_result_t mraa_setup_mux_mapped(mraa_pin_t meta); /** * runtime detect running x86 platform * * @return mraa_platform_t of the init'ed platform */ mraa_platform_t mraa_x86_platform(); /** * runtime detect running arm platforms * * @return mraa_platform_t of the init'ed platform */ mraa_platform_t mraa_arm_platform(); /** * runtime detect running mips platforms * * @return mraa_platform_t of the init'ed platform */ mraa_platform_t mraa_mips_platform(); /** * setup a mock platform * * @return mraa_platform_t of the init'ed platform */ mraa_platform_t mraa_mock_platform(); /** * runtime detect running risc-v platforms * * @return mraa_platform_t of the init'ed platform */ mraa_platform_t mraa_riscv_platform(); /** * runtime detect iio subsystem * * @return mraa_result_t indicating success of iio detection */ mraa_result_t mraa_iio_detect(); /** * helper function to check if file exists * * @param filename to check * @return mraa_boolean_t boolean result. */ mraa_boolean_t mraa_file_exist(const char* filename); /** * helper function to unglob filenames * * @param filename to unglob * @return char * with the existing filename matching the pattern of input. NULL if there is no *match. Caller must free result */ char* mraa_file_unglob(const char* filename); /** * helper function to check if file contains a given text * * @param filename to check * @param content to check in file * @return mraa_boolean_t boolean result. */ mraa_boolean_t mraa_file_contains(const char* filename, const char* content); /** * helper function to check if file contains a given text * * @param filename to check * @param content to check in file * @param content2 to check in same line of file * @return mraa_boolean_t boolean result. */ mraa_boolean_t mraa_file_contains_both(const char* filename, const char* content, const char* content2); /** * helper function to find out if file that is targeted by a softlink * (partially) matches the given name * * @param filename of the softlink * @param (partial) filename that is matched with the filename of the link-targeted file * @return mraa_boolean_t true when targetname (partially) matches */ mraa_boolean_t mraa_link_targets(const char* filename, const char* targetname); /** * helper function to find the first i2c bus containing devname starting from * i2c-n where n is startfrom * * @param device name to match * @param i2c-dev number to start search from * @return the matching i2c-dev bus id or -1 */ int mraa_find_i2c_bus(const char* devname, int startfrom); /** * helper function to wrap strtol for our basic usage * * @param string representing int * @param converted string * @return Result of the operation */ mraa_result_t mraa_atoi(char* intStr, int* value); /** * helper function to find an i2c bus based on pci data * * @param pci_device * @param pci_id on pci_device * @param i2c adapter name & number * @return the matching i2c-dev bus id or -1 */ int mraa_find_i2c_bus_pci(const char* pci_device, const char *pci_id, const char* adapter_name); /** * helper function to find the uart device based on pci data * * @param pci_dev_path points to the location of tty device which corresponds * to the uart device available on the platform * @param dev_name as retrieved from pci_dev_path * @return Result of the operation */ mraa_result_t mraa_find_uart_bus_pci(const char* pci_dev_path, char** dev_name); #if defined(IMRAA) /** * read Imraa subplatform lock file, caller is responsible to free return * struct array * * @param imraa lockfile location * @return the number of subplatforms added */ uint32_t mraa_add_from_lockfile(const char* imraa_lock_file); /** * Internal imraa init function * * @return mraa_result_t indicating success */ mraa_result_t imraa_init(); #endif #ifdef __cplusplus } #endif