[ dakinet @ 12.11.2022. 11:41 ] @
Kupio sam nekoliko modula Ra-08h sa idejom da napravim jednostavnu komunikaciju između 2 uređaja. Na prvom čitam input pin, info prenesem preko LoRa mreže do drugog uređaja gde aktiviram out pin.
Preuzeo sam primere sa sajta: https://github.com/Ai-Thinker-Open/Ai-Thinker-LoRaWAN-Ra-08
Za programiranje se koristi keil uVision5 u kombinacijom sa GCC kompajlerom info:
Code:

IDE-Version:
µVision V5.37.0.0
Copyright (C) 2022 ARM Ltd and ARM Germany GmbH. All rights reserved.

License Information:
dak d
ttv
LIC=----

Tool Version Numbers:
Toolchain:        MDK-Lite  Version: <unknown>
Toolchain Path:    C:\Program Files (x86)\GNU Arm Embedded Toolchain\9 2020-q2-update\bin
C Compiler:         GCC.exe
Assembler:          AS.exe
Linker/Locator:     LD.exe
Librarian:             AR.exe
Hex Converter:      OBJCOPY.exe
CPU DLL:               SARMCM3.DLL    
Dialog DLL:         TCM.DLL        
Target DLL:         Segger\JL2CM3.DLL
Dialog DLL:         TCM.DLL        


Alat za flešovanje bin fajla u uC: https://docs.ai-thinker.com/_media/firmware_update_tool.zip



Zna li neko kako da pročitam status sa IO8 pina i odštampam vrednos na uart?


main.c
Code:
#include <stdio.h>
#include <stdarg.h>
#include "tremo_uart.h"
#include "tremo_gpio.h"
#include "tremo_rcc.h"
#include "tremo_delay.h"

#define TEST_GPIOX GPIOA
#define TEST_PIN   GPIO_PIN_4
//-----------------definicija ulaznih pinova==================
#define INGPIO8 GPIOA
#define INPUTIO8 GPIO_PIN_8

void uart_log_init(void)
{
    // uart0
    gpio_set_iomux(GPIOB, GPIO_PIN_0, 1);
    gpio_set_iomux(GPIOB, GPIO_PIN_1, 1);

    /* uart config struct init */
    uart_config_t uart_config;
    uart_config_init(&uart_config);

    uart_config.baudrate = UART_BAUDRATE_115200;
    uart_init(CONFIG_DEBUG_UART, &uart_config);
    uart_cmd(CONFIG_DEBUG_UART, ENABLE);
}

int main(void)
{
    rcc_enable_peripheral_clk(RCC_PERIPHERAL_UART0, true);
    rcc_enable_peripheral_clk(RCC_PERIPHERAL_GPIOB, true);
    
      rcc_enable_peripheral_clk(RCC_PERIPHERAL_GPIOA, true);
    gpio_init(TEST_GPIOX, TEST_PIN, GPIO_MODE_OUTPUT_PP_HIGH);
    
      rcc_enable_peripheral_clk(RCC_PERIPHERAL_GPIOA, true);
    gpio_init(INGPIO8, INPUTIO8, GPIO_MODE_INPUT_PULL_UP);

    uart_log_init();
     printf("Inicijalizacija serijskog porta\r\n");

    /* Infinite loop */
    while (1) {
 printf("hello world\r\n");
             gpio_toggle(TEST_GPIOX, TEST_PIN);
            delay_ms(1000);
            printf("PIN8 status=");
            int pera= (gpio_level_t gpio_read(gpio_t* TEST_GPIOX, uint8_t INPUTIO8));
            //printf('gpio_level_t gpio_read(gpio_t* TEST_GPIOX, uint8_t INPUTIO8)');
            //printf(assert_param(IS_GPIO_PIN(TEST_GPIOX, INPUTIO8)));
        }
}

#ifdef USE_FULL_ASSERT
void assert_failed(void* file, uint32_t line)
{
    (void)file;
    (void)line;

    while (1) { }
}
#endif






Ispod je sadržaj fajla "tremo_gpio.c"
Code:
#include <stdbool.h>
#include "tremo_rcc.h"
#include "tremo_gpio.h"

/**
 * @brief Deinitializes the GPIO registers to the reset values
 * @note This will reset all the registers of GPIOA, GPIOB, GPIOC and GPIOD
 * @param None
 * @retval None
 */
void gpio_deinit(void)
{
    rcc_enable_peripheral_clk(RCC_PERIPHERAL_GPIOA, false);
    rcc_enable_peripheral_clk(RCC_PERIPHERAL_GPIOB, false);
    rcc_enable_peripheral_clk(RCC_PERIPHERAL_GPIOC, false);
    rcc_enable_peripheral_clk(RCC_PERIPHERAL_GPIOD, false);
    rcc_rst_peripheral(RCC_PERIPHERAL_GPIOA, true);
    rcc_rst_peripheral(RCC_PERIPHERAL_GPIOA, false);
}

/**
 * @brief Init the GPIOx according to the specified parameters
 * @note  The default mode of the gpio is GPIO_MODE_ANALOG.
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @param mode Select the GPIO mode. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_MODE_INPUT_FLOATING:  Input floating
 *           @arg GPIO_MODE_INPUT_PULL_UP:   Input pull-up
 *           @arg GPIO_MODE_INPUT_PULL_DOWN: Input pull-down
 *           @arg GPIO_MODE_OUTPUT_PP_HIGH:  Output push-pull high level
 *           @arg GPIO_MODE_OUTPUT_PP_LOW:   Output push-pull low level
 *           @arg GPIO_MODE_OUTPUT_OD_HIZ:   Output open-drain high-impedance
 *           @arg GPIO_MODE_OUTPUT_OD_LOW:   Output open-drain low level
 *           @arg GPIO_MODE_ANALOG:          Analog
 * @retval None
 */
void gpio_init(gpio_t* gpiox, uint8_t gpio_pin, gpio_mode_t mode)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));
    assert_param(IS_GPIO_MODE(mode));

    switch (mode) {
    case GPIO_MODE_INPUT_FLOATING: {
        gpiox->OER |= (1 << gpio_pin);
        gpiox->IER |= (1 << gpio_pin);
        gpiox->PER &= ~(1 << gpio_pin);
        break;
    }
    case GPIO_MODE_INPUT_PULL_UP: {
        gpiox->OER |= (1 << gpio_pin);
        gpiox->IER |= (1 << gpio_pin);
        gpiox->PER |= (1 << gpio_pin);
        gpiox->PSR |= (1 << gpio_pin);
        break;
    }
    case GPIO_MODE_INPUT_PULL_DOWN: {
        gpiox->OER |= (1 << gpio_pin);
        gpiox->IER |= (1 << gpio_pin);
        gpiox->PER |= (1 << gpio_pin);
        gpiox->PSR &= ~(1 << gpio_pin);
        break;
    }
    case GPIO_MODE_OUTPUT_PP_HIGH: {
        gpiox->OER &= ~(1 << gpio_pin);
        gpiox->IER &= ~(1 << gpio_pin);
        gpiox->OTYPER &= ~(1 << gpio_pin);
        gpiox->ODR |= (1 << gpio_pin);
        break;
    }
    case GPIO_MODE_OUTPUT_PP_LOW: {
        gpiox->OER &= ~(1 << gpio_pin);
        gpiox->IER &= ~(1 << gpio_pin);
        gpiox->OTYPER &= ~(1 << gpio_pin);
        gpiox->ODR &= ~(1 << gpio_pin);
        break;
    }
    case GPIO_MODE_OUTPUT_OD_HIZ: {
        if (gpiox == GPIOD && gpio_pin > GPIO_PIN_7) {
            gpiox->ODR &= ~(1 << gpio_pin);
            gpiox->IER &= ~(1 << gpio_pin);
            gpiox->OER |= (1 << gpio_pin);
            gpiox->PSR &= ~(1 << gpio_pin);
        } else {
            gpiox->OER &= ~(1 << gpio_pin);
            gpiox->IER &= ~(1 << gpio_pin);
            gpiox->OTYPER |= (1 << gpio_pin);
            gpiox->ODR |= (1 << gpio_pin);
        }
        break;
    }
    case GPIO_MODE_OUTPUT_OD_LOW: {
        if (gpiox == GPIOD && gpio_pin > GPIO_PIN_7) {
            gpiox->ODR &= ~(1 << gpio_pin);
            gpiox->IER &= ~(1 << gpio_pin);
            gpiox->OER &= ~(1 << gpio_pin);
            gpiox->PSR &= ~(1 << gpio_pin);
        } else {
            gpiox->OER &= ~(1 << gpio_pin);
            gpiox->IER &= ~(1 << gpio_pin);
            gpiox->OTYPER |= (1 << gpio_pin);
            gpiox->ODR &= ~(1 << gpio_pin);
        }
        break;
    }
    default:
    case GPIO_MODE_ANALOG: {
        gpiox->OER |= (1 << gpio_pin);
        gpiox->IER &= ~(1 << gpio_pin);
        gpiox->PER &= ~(1 << gpio_pin);
        break;
    }
    }
}

/**
 * @brief Set the output level
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @param level Output level.
 *          This parameter can be one of the following values:
 *           @arg GPIO_LEVEL_HIGH: high level
 *           @arg GPIO_LEVEL_LOW:  low level
 * @retval None
 */
void gpio_write(gpio_t* gpiox, uint8_t gpio_pin, gpio_level_t level)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));

    if (level != GPIO_LEVEL_LOW)
        gpiox->BSR |= 1 << gpio_pin;
    else
        gpiox->BRR |= 1 << gpio_pin;
}

/**
 * @brief Read the input level
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @retval GPIO_LEVEL_HIGH High level
 * @retval GPIO_LEVEL_LOW Low level
 */
gpio_level_t gpio_read(gpio_t* gpiox, uint8_t gpio_pin)
{
    /* Check the parameters */
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));

    return ((gpiox->IDR & (1 << gpio_pin)) ? GPIO_LEVEL_HIGH : GPIO_LEVEL_LOW);
}

/**
 * @brief Toggle the specified GPIO pin
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @retval None
 */
void gpio_toggle(gpio_t* gpiox, uint8_t gpio_pin)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));

    gpiox->ODR ^= (1 << gpio_pin);
}

/**
 * @brief Config the output drive capability of the specified GPIO pin
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @param drive Output drive capability.
 *          This parameter can be one of the following values:
 *           @arg GPIO_DRIVE_CAPABILITY_4MA: The max current is 4mA
 *           @arg GPIO_DRIVE_CAPABILITY_8MA: The max current is 8mA
 * @retval None
 */
void gpio_config_drive_capability(gpio_t* gpiox, uint8_t gpio_pin, gpio_drive_capability_t drive)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));

    if (drive)
        gpiox->DSR |= 1 << gpio_pin;
    else
        gpiox->DSR &= ~(1 << gpio_pin);
}

/**
 * @brief Config the interrupt type of the specified GPIO pin
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @param intr_type The interrupt type.
 *          This parameter can be one of the following values:
 *           @arg GPIO_INTR_NONE: Disable GPIO interrupt
 *           @arg GPIO_INTR_RISING_EDGE: Rising edge
 *           @arg GPIO_INTR_FALLING_EDGE: Falling edge
 *           @arg GPIO_INTR_RISING_FALLING_EDGE: Both rising and falling edg
 * @retval None
 */
void gpio_config_interrupt(gpio_t* gpiox, uint8_t gpio_pin, gpio_intr_t intr_type)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));
    assert_param(IS_GPIO_INTR(intr_type));

    gpio_clear_interrupt(gpiox, gpio_pin);
    TREMO_REG_SET(gpiox->ICR, (0x3 << 2 * gpio_pin), (intr_type << 2 * gpio_pin));
}

/**
 * @brief Clear the interrupt status of the specified GPIO pin
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @retval None
 */
void gpio_clear_interrupt(gpio_t* gpiox, uint8_t gpio_pin)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));

    gpiox->IFR = (gpiox->IFR & 0x3 << 2 * gpio_pin);
}

/**
 * @brief Get the interrupt status of the specified GPIO pin
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @retval it_status_t The interrupt status of the specified GPIO pin(SET or RESET)
 */
it_status_t gpio_get_interrupt_status(gpio_t* gpiox, uint8_t gpio_pin)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));
    return (gpiox->IFR & (0x3 << 2 * gpio_pin)) ? SET : RESET;
}

/**
 * @brief Config the wakeup setting of the specified GPIO pin
 * @note This function is used to config the wakeup setting in stop0/1/2 mode
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @param enable If set to true, this gpio can wakeup the system from stop0/1/2 mode.
 * @param wakeup_level Wakeup level.
 *          This parameter can be one of the following values:
 *           @arg GPIO_LEVEL_HIGH: high level
 *           @arg GPIO_LEVEL_LOW:  low level
 * @retval None
 */
void gpio_config_wakeup(gpio_t* gpiox, uint8_t gpio_pin, bool enable, gpio_level_t wakeup_level)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));

    // stop0-2
    TREMO_REG_EN(gpiox->WUCR, (1 << gpio_pin), enable);
    TREMO_REG_EN(gpiox->WULVL, (1 << gpio_pin), wakeup_level > 0);
}

/**
 * @brief Config the wakeup setting of the specified GPIO pin
 * @note This function is used to config the wakeup setting of GPIO0-GPIO55 in stop3 mode.
 *          In stop3 mode, the GPIO0-GPIO55 are divided to 14 groups. Only one gpio in the group can be configed to wakeup the system at the same time.
 *           The following are the groups:
 *           - GPIOA_0/1/2/3
 *           - GPIOA_4/5/12/13
 *           - GPIOA_8/9/10/11
 *           - GPIOA_6/7/14/15
 *           - GPIOB_0/1/2/3
 *           - GPIOB_4/5/6/7
 *           - GPIOB_8/9/10/11
 *           - GPIOB_12/13/14/15
 *           - GPIOC_0/1/2/3
 *           - GPIOC_4/5/6/7
 *           - GPIOC_8/9/10/11
 *           - GPIOC_12/13/14/15
 *           - GPIOD_0/1/2/3
 *           - GPIOD_4/5/6/7
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @param enable If set to true, this gpio can wakeup the system from stop3 mode.
 * @param wakeup_level Wakeup level.
 *          This parameter can be one of the following values:
 *           @arg GPIO_LEVEL_HIGH: high level
 *           @arg GPIO_LEVEL_LOW:  low level
 * @retval None
 */
void gpio_config_stop3_wakeup(gpio_t* gpiox, uint8_t gpio_pin, bool enable, gpio_level_t wakeup_level)
{
    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));
    if (gpio_pin > GPIO_PIN_7 && gpiox == GPIOD)
        return;

    if (gpiox == GPIOA) {
        if (gpio_pin == GPIO_PIN_6 || gpio_pin == GPIO_PIN_7)
            gpio_pin += 6;
        else if (gpio_pin == GPIO_PIN_12 || gpio_pin == GPIO_PIN_13)
            gpio_pin -= 6;
    }

    uint32_t group    = gpio_pin / 4;
    uint32_t offset   = gpio_pin % 4;
    uint32_t tmp_mask = 0xF;
    uint32_t tmp      = offset | (wakeup_level ? 0x4 : 0x0) | (enable ? 0x8 : 0x0);

    TREMO_REG_SET(gpiox->STOP3_WUCR, (tmp_mask << (4 * group)), (tmp << (4 * group)));
}

/**
 * @brief Config iomux of the specified GPIO pin
 * @param gpiox Select the GPIO peripheral number(GPIOA, GPIOB, GPIOC and GPIOD)
 * @param gpio_pin Select the GPIO pin number. 
 *          This parameter can be one of the following values:
 *           @arg GPIO_PIN_0:  Pin 0
 *           @arg GPIO_PIN_1:  Pin 1
 *           @arg GPIO_PIN_2:  Pin 2
 *           @arg GPIO_PIN_3:  Pin 3
 *           @arg GPIO_PIN_4:  Pin 4
 *           @arg GPIO_PIN_5:  Pin 5
 *           @arg GPIO_PIN_6:  Pin 6
 *           @arg GPIO_PIN_7:  Pin 7
 *           @arg GPIO_PIN_8:  Pin 8
 *           @arg GPIO_PIN_9:  Pin 9
 *           @arg GPIO_PIN_10: Pin 10
 *           @arg GPIO_PIN_11: Pin 11
 *           @arg GPIO_PIN_12: Pin 12
 *           @arg GPIO_PIN_13: Pin 13
 *           @arg GPIO_PIN_14: Pin 14
 *           @arg GPIO_PIN_15: Pin 15
 * @param func_num The function number.
 *          This parameter can be one of the following values:
 *           @arg 0: The Function number 0, which is always GPIO function
 *           @arg 1: The Fucntion number 1, please refer to the IOMUX spec
 *           @arg 2: The Fucntion number 2, please refer to the IOMUX spec
 *           @arg 3: The Fucntion number 3, please refer to the IOMUX spec
 *           @arg 4: The Fucntion number 4, please refer to the IOMUX spec
 *           @arg 5: The Fucntion number 5, please refer to the IOMUX spec
 *           @arg 6: The Fucntion number 6, please refer to the IOMUX spec
 *           @arg 7: The Fucntion number 7, please refer to the IOMUX spec
 * @retval None
 */
void gpio_set_iomux(gpio_t* gpiox, uint8_t gpio_pin, uint8_t func_num)
{
    uint32_t tmp_mask = 0;
    uint32_t tmp      = 0;

    assert_param(IS_GPIO_PIN(gpiox, gpio_pin));

    if (gpio_pin > GPIO_PIN_7) {
        uint32_t index = gpio_pin - GPIO_PIN_8;
        tmp_mask       = (gpiox == GPIOD) ? (0x7 << (3 * index)) : (0xF << (4 * index));
        tmp            = (gpiox == GPIOD) ? (func_num << (3 * index)) : (func_num << (4 * index));

        TREMO_REG_SET(gpiox->AFRH, tmp_mask, tmp);
    } else {
        tmp_mask = (0xF << (4 * gpio_pin));
        tmp      = (func_num << (4 * gpio_pin));
        TREMO_REG_SET(gpiox->AFRL, tmp_mask, tmp);
    }
}



Plaćam ko može da mi pomogne sa ovim
pozdrav






[ dakinet @ 12.11.2022. 23:03 ] @
Uspeo.
"gpio_read(GPIOA, GPIO_PIN8);"

Ustvari je bilo vrlo jednostavno samo što ja nisam radio ništa osim Arduina pa pola stvari ne razumem ovde.

Funkcija mi vraća vrednost 0 ili 1.

Postoji funkcija koja štampa vrednost koju pročitam na uart:

"printf(gpio_read(GPIOA, GPIO_PIN8));"

ne štampa mi u terminalu ispravno kako je pročitano (0 ili 1) već "@" kada je 1 i prazan karakter " " kada je 0. Zna li neko možda što je ovo ovako?

Uspeo sam i da aktiviram led na GPIO pinu, funkcija je:

"gpio_write(GPIOA, GPIO_PIN4, GPIO_MODE_OUTPUT_PP_HIGH);" aktivira led na gpio pinu
"gpio_write(GPIOA, GPIO_PIN4, GPIO_MODE_OUTPUT_PP_LOW);" deaktivira led na gpio pinu

Sada mi ostaje da probam da aktiviram radio vezu LoRa i da pošaljem komandu sa uređaja A na uređaj B.
[ bogdan.kecman @ 13.11.2022. 03:13 ] @
Citat:
dakinet
"printf(gpio_read(GPIOA, GPIO_PIN8));"

ne štampa mi u terminalu ispravno kako je pročitano (0 ili 1) već "@" kada je 1 i prazan karakter " " kada je 0. Zna li neko možda što je ovo ovako?


printf zahteva da mu kazes kako sta stampas, koji ti je to kompajler?

Code:

printf("%i\n", gpio_read(GPIOA, GPIO_PIN8)); // ovako stampas integer
printf("%d\n", gpio_read(GPIOA, GPIO_PIN8)); // eventualno ovako stampas integer 
printf("%s\n", gpio_read(GPIOA, GPIO_PIN8)==0?"Nula":"Jedan"); // ovako stampas string

printf (gpio_read(GPIOA, GPIO_PIN8)==0?"Nula":"Jedan"); // mozda ti ovako nesto radi ali ovo nije standardan printf, mozda u tvoj kompajleru postoji moz probas

// a mozes i seljacki

if (gpio_read(GPIOA, GPIO_PIN8)){
  printf("jedan\n");
} else {
  printf("nula\n");
}


[ tomam @ 13.11.2022. 06:53 ] @

"printf(gpio_read(GPIOA, GPIO_PIN8)+'0');"
ili

"printf(gpio_read(GPIOA, GPIO_PIN8)+"0");"

printf ocekule ASC_i COD ne numericku / logicku vrednost
[ dakinet @ 13.11.2022. 17:58 ] @
@bogdan.kecman
Citat:
printf zahteva da mu kazes kako sta stampas, koji ti je to kompajler?


C Compiler: GCC.exe


Ma da ja ne znam ovde kako su uvezani svi ovi fajlovi. Kada krene da kompajlira uVision proverava gomilu nekih .h i .c fajlova, evo ispod kako to izgleda. Ja posle samo puknem bin fajl programatorom na kontroler.
Code:

Rebuild started: Project: project
Rebuild target 'project'
compiling startup_cm4.S...
compiling system_cm4.c...
compiling tremo_adc.c...
compiling tremo_bstimer.c...
compiling tremo_crc.c...
compiling printf-stdarg.c...
compiling tremo_dac.c...
compiling tremo_delay.c...
compiling tremo_flash.c...
compiling tremo_gpio.c...
compiling tremo_dma.c...
compiling tremo_i2c.c...
compiling tremo_i2s.c...
compiling tremo_iwdg.c...
compiling tremo_lcd.c...
compiling tremo_lptimer.c...
compiling tremo_lpuart.c...
compiling tremo_pwr.c...
compiling tremo_spi.c...
compiling tremo_rcc.c...
compiling tremo_rtc.c...
compiling tremo_system.c...
compiling tremo_wdg.c...
compiling tremo_timer.c...
compiling tremo_uart.c...
compiling tremo_it.c...
compiling main.c...
linking...
creating hex file...
After Build - User command #1: .\utils\genbinary.bat
C:\Radno\ra08\projects\ASR6601CB-EVAL\examples\uart\uart_printf>..\..\..\..\..\tools\hex2bin\hex2bin.exe .\Objects\project.hex 
hex2bin v2.5, Copyright (C) 2017 Jacques Pelletier & contributors
Allocate_Memory_and_Rewind:
Lowest address:   08000000
Highest address:  08002E6B
Starting address: 08000000
Max Length:       11884
Binary file start = 08000000
Records start     = 08000000
Highest address   = 08002E6B
Pad Byte          = FF
".\Objects\project.elf" - 0 Error(s), 0 Warning(s).
Build Time Elapsed:  00:00:05



@tomam
Izgubio sam tvoj broj telefona.

Citat:
"printf(gpio_read(GPIOA, GPIO_PIN8)+'0');"
ili

"printf(gpio_read(GPIOA, GPIO_PIN8)+"0");"

printf ocekule ASC_i COD ne numericku / logicku vrednost


Podelio sam u dva koraka, u prvom čitam pin i rezultat smeštam u int. U drugom koraku štampam vrednost int. na uart.

Code:
pera=gpio_read(TEST_GPIOX, INPUTIO8); //procitaj vrednost IO8
zika=gpio_read(TEST_GPIOX, INPUTIO11); //procitaj vrednost IO11
mika=gpio_read(TEST_GPIOX, INPUTIO9); //procitaj vrednost IO9 

//
printf("GPIO8 = %d  I  ", pera);
printf("GPIO11 =%d  I  ", zika);
printf("GPIO9 =%d \n", mika);

//Rezultat se štampa u jednom redu ovako "GPIO8 = 1 I GPIO11 = 1 I GPIO9 = 1"



[ dakinet @ 13.11.2022. 20:44 ] @
Komunikacija bežična između dva uređaja preko LoRa standarda. Da li je neko radio nešto sa ovim radio standardom?

Ja sam to ovako razumeo da treba da radi:



Uređaj A (master) šalje komandu slave uređaju
-Pročitaj status sa 3 IO pina
-Aktivira relej 1
-Aktiviraj relej 2
-Aktiviraj relej 3
-Aktiviraj releje 1,2,3

Uređaj B (slave) treba da bude u režinu prijem.
-čita statuse sa 3 IO
-Aktivira releje
-vraća potvrdu da je komanda izvršena.


[ dakinet @ 14.11.2022. 10:00 ] @
Pokušavam da pošaljem pročitanu vrednost sa 3 IO pina radio vezom LoRa.

Code:

//Čitanje statusa IO pinaova 
pera=gpio_read(TEST_GPIOX, INPUTIO8); //procitaj vrednost IO8
zika=gpio_read(TEST_GPIOX, INPUTIO11); //procitaj vrednost IO11
mika=gpio_read(TEST_GPIOX, INPUTIO9); //procitaj vrednost IO9


//Pretvaranje int u char

if (pera==1){
Buffer[0] = '1';
}
else if (pera==0){
Buffer[0] = '0'; 
}

if (zika==1){
Buffer[1] = '1';
}
else if (zika==0){
Buffer[1] = '0'; 
}

if (mika==1){
Buffer[2] = '1';
}
else if (mika==0){
Buffer[2] = '0'; 
}


//Definisanje radio veze LoRa

#define RF_FREQUENCY                                868000000 // Hz
#define TX_OUTPUT_POWER                             14        // dBm
#define LORA_BANDWIDTH                              0         // [0: 125 kHz,
                                                              //  1: 250 kHz,
                                                              //  2: 500 kHz,
                                                              //  3: Reserved]
#define LORA_SPREADING_FACTOR                       7         // [SF7..SF12]
#define LORA_CODINGRATE                             1         // [1: 4/5,
                                                              //  2: 4/6,
                                                              //  3: 4/7,
                                                              //  4: 4/8]
#define LORA_PREAMBLE_LENGTH                        8         // Same for Tx and Rx
#define LORA_SYMBOL_TIMEOUT                         0         // Symbols
#define LORA_FIX_LENGTH_PAYLOAD_ON                  false
#define LORA_IQ_INVERSION_ON                        false


//Slanje pročitanih pinova radio vezom LoRa
BufferSize = 3;

 Radio.Send( Buffer, BufferSize );

Delay_Ms(1000);



Radi! na prijemnoj strani dobijam karaktere "111" ili "000" u zavisnosti koji su tasteri pritisnuti.

Funkcija Radio.Send zahteva da se definišu karakteri char[] na bitovima od 0-3
Da li postoji elegantnije rešenje da se 3 pročitana pina pretvore u char?

[ dakinet @ 18.11.2022. 16:04 ] @
Zna li neko kako ova funkcija radi?
Ovo je zapravo procesiranje primljenih telegrama. Znam samo da je "Buffer" promenjiva koja drži primljeni telegram, "PongMsg" je constanta koja drži string "PONG".

Code:



if( strncmp( ( const char* )Buffer, ( const char* )PongMsg, 4 ) == 0 )
                    {
                      
                        //Štampaj PONG 
                       printf("Received: PONG\r\n");
                        
                     }




Ovoj gore funkciji prethodi inicijalni kod gde su definisane ove promenjive:

Code:
#define BUFFER_SIZE                                 5 // Define the payload size here

const uint8_t PongMsg[] = "PONG";

uint16_t BufferSize = BUFFER_SIZE;

uint8_t Buffer[BUFFER_SIZE];

int     strncmp (const char *, const char *, size_t); //promenjiva definisana u "strings.h"

[ bogdan.kecman @ 18.11.2022. 16:14 ] @
Code:
strncmp( ( const char* )Buffer, ( const char* )PongMsg, 4 )


ovo poredi sadrzaj Buffer i PongMsg i to samo prva 4 bajta (ako je neki bajt 0 poredi do tog bajta ali najduze 4 bajta)

Code:
if( strncmp(...) == 0 )


ovo proverava da li je rezultat poredjenja 0. strcmp vraca 0 ako su stringovi isti, dakle ako su prva 4 karaktera u Buffer i PongMsg ista if ce se izvrsiti dakle stampace ti "Received: PONG"




[ dakinet @ 18.11.2022. 18:28 ] @
hvala na detaljnom objašnjenju. Ovo će mi onda rešiti sve što mi treba, naime...

Zbog sigurnosti i mogućnosti slučajne aktivacije ulaza izlaza od strane drugih LoRa predajnika došao sam na ideju da predajnik i prijemnik imaju neke adrese.
-predajnik 2 bajta "T1"
-Prijemnik 2 bajta "R2"
-Komanda 6 bajta "sssOOO"

tako da finalni telegram izgleda ovako "T1R2sssooo" (od čega sss će biti statusi 3 ulaza; OOO statusi 3 izlaza.)

Sad kad budem ovaj telegram propustio kroz funkciju "if( strncmp( ( const char* )Buffer, ( const char* )PongMsg, 2) == 0 )"
dobiću prva dva bajta, tj adresu predajnika "T1". Ako je adresa tačna onda bih ponovo pozvao ovu funkciju s tim što bi u drugom koraku čitao ceo telegram.
"if( strncmp( ( const char* )Buffer, ( const char* )PongMsg, 10) == 0 )" će pročitati svih 10 bajta. Onda mi ostaje da napravim par konstanti koje će držati komande:
"T1R2RRRooo" =pročitaj status 3 ulaza
"T1R2sssOoo" =aktiviraj O1 (relej1), isključi sve ostale
"T1R2sssoOo" =aktiviraj O2 (relej2), isključi sve ostale
"T1R2sssooO" =aktiviraj O3 (relej3), isključi sve ostale
"T1R2sssOOO" =aktiviraj O1-3 (svi releji)
"T1R2sssooo" =isključi sve O1-3 (svi releji)

kad uporedim ove konstante sa primljenim telegramom ako rezultat poređenja bude ==0 ;
Izvrši komande;
Pošalji telegram nazad, komanda izvršena

Odo da probam super hvala