Large change that removes the duplicated MIT notice withe a spdx tag Signed-off-by: Thomas Ingleby <thomas.ingleby@intel.com>
178 lines
4.3 KiB
C
178 lines
4.3 KiB
C
/*
|
|
* Author: Thomas Ingleby <thomas.c.ingleby@intel.com>
|
|
* Copyright (c) 2014 Intel Corporation.
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <syslog.h>
|
|
#include <fnmatch.h>
|
|
|
|
#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 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
|