From: Thomas Ingleby Date: Wed, 30 Apr 2014 10:13:36 +0000 (+0100) Subject: pinmap: More work around abstracting pin information X-Git-Tag: v0.2.2~9^2~2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d4427ec35e259debfbb91351e64df48152736543;p=contrib%2Fmraa.git pinmap: More work around abstracting pin information Signed-off-by: Thomas Ingleby --- diff --git a/api/maa.h b/api/maa.h index 67f0248..589209a 100644 --- a/api/maa.h +++ b/api/maa.h @@ -79,6 +79,7 @@ typedef struct { unsigned int maa_check_gpio(int pin); unsigned int maa_check_aio(int pin); +unsigned int maa_check_pwm(int pin); /** Get the version string of maa autogenerated from git tag * diff --git a/src/maa.c b/src/maa.c index 8301017..6b772be 100644 --- a/src/maa.c +++ b/src/maa.c @@ -42,6 +42,18 @@ maa_init() return MAA_ERROR_FEATURE_NOT_IMPLEMENTED; } +static maa_result_t +maa_setup_mux_mapped(maa_pininfo meta) +{ + int mi; + for(mi = 0; mi < meta.mux_total; mi++) { + maa_gpio_context* mux_i; + mux_i = maa_gpio_init_raw(meta.mux[mi].pin); + maa_gpio_dir(mux_i, MAA_GPIO_OUT); + maa_gpio_write(mux_i, meta.mux[mi].value); + } +} + unsigned int maa_check_gpio(int pin){ @@ -49,18 +61,10 @@ maa_check_gpio(int pin){ return -1; } //Check in gpio bounds? - if(pindata[pin].mux_total > 0) { - int mi; - for(mi = 0; mi < pindata[pin].mux_total; mi++) { - //Do we want to keep the gpio object around - //I dont think so - maa_gpio_context* mux_i; - //TODO CHANGE TO RAW - mux_i = maa_gpio_init(pindata[pin].mux[mi].pin); - maa_gpio_dir(mux_i, "out"); - maa_gpio_write(mux_i, pindata[pin].mux[mi].value); - } - } - return pindata[pin].pin + if(pindata[pin].mux_total > 0) + if(maa_setup_mux_mapped(pindata[pin]) != MAA_SUCCESS) + return -1; + + return pindata[pin].pin; }