collapse

* Posts Recentes

Meu novo robô por josecarlos
[Ontem às 21:23]


Spot Welder - O que acham? por almamater
[06 de Setembro de 2024, 15:07]


Transmissão de energia sem fios por dropes
[02 de Setembro de 2024, 13:31]


Fita Isoladora - Tipos ou Qualidades diferentes? por dropes
[21 de Agosto de 2024, 15:53]


Cabo/Tubo? para passar ligação sensores - horta por SerraCabo
[21 de Agosto de 2024, 12:14]


Impressora - Valerá a pena? por dropes
[16 de Agosto de 2024, 17:09]


Fonte Monitor Samsung por jm_araujo
[14 de Agosto de 2024, 14:49]


Shelly em jeito de watchdog por SerraCabo
[10 de Agosto de 2024, 22:13]


[RESOLVIDO] Browser TV JVC por KammutierSpule
[07 de Agosto de 2024, 10:16]


Sirene NOVA maluca por m90mine
[31 de Julho de 2024, 12:39]

Autor Tópico: Embedded Systems - Shape The World com TIVA TM4C123  (Lida 10886 vezes)

0 Membros e 1 Visitante estão a ver este tópico.

Offline LuísR.A.

  • Mini Robot
  • *
  • Mensagens: 1.224
    • Clube de Robotica
Re: Embedded Systems - Shape The World com TIVA TM4C123
« Responder #15 em: 28 de Janeiro de 2015, 14:31 »
Por acaso já pensei mexer nesse Psoc mas tava a pensar usar o IDE grafico. Mas sinceramente é preciso é ter calma. Agora ando a experimentar os STM32.

Senso eu se quiser uso o TivaWare para programar só com macros tambem! De forma a facilitar. É o que faço quando quero usar só registos.
Mas lembro-me de um vez que tive de desbloquear o micro com uma ferramenta, apagar tudo na flash... tava la algo mal. Com o TivaWare isso nunca me aconteceu



Tiva MCU é que é.

Tutoriais Tiva+codigos exemplo:
https://sites.google.com/site/luiselectronicprojects/

StarRider

  • Visitante
Re: Embedded Systems - Shape The World com TIVA TM4C123
« Responder #16 em: 28 de Janeiro de 2015, 14:33 »
Calma eu não vou ao cumulo de escrever algo assim:
(APB2PERIPH_BASE + 0x2400) |= 0xFFEC01AD;
 
Seria mais algo no género: *((uint32_t *) (APB2PERIPH_BASE + 0x2400)) |= 0xFFEC01AD

Abraços,
PA


Offline senso

  • Global Moderator
  • Mini Robot
  • *****
  • Mensagens: 9.733
  • Helpdesk do sitio
Re: Embedded Systems - Shape The World com TIVA TM4C123
« Responder #17 em: 28 de Janeiro de 2015, 14:38 »
Woosh  ;D
Avr fanboy

Offline LuísR.A.

  • Mini Robot
  • *
  • Mensagens: 1.224
    • Clube de Robotica
Re: Embedded Systems - Shape The World com TIVA TM4C123
« Responder #18 em: 28 de Janeiro de 2015, 14:44 »
Calma eu não vou ao cumulo de escrever algo assim:
(APB2PERIPH_BASE + 0x2400) |= 0xFFEC01AD;
 
Seria mais algo no género: *((uint32_t *) (APB2PERIPH_BASE + 0x2400)) |= 0xFFEC01AD

Abraços,
PA



Precisa de levar um casting antes de ser usado como endereço? 
Tiva MCU é que é.

Tutoriais Tiva+codigos exemplo:
https://sites.google.com/site/luiselectronicprojects/

Offline Electropepper

  • Mini Robot
  • *
  • Mensagens: 116
    • Electropepper
Re: Embedded Systems - Shape The World com TIVA TM4C123
« Responder #19 em: 28 de Janeiro de 2015, 14:59 »
Eu sou da mesma opinião que o senso, demasiada biblioteca ás vezes torna tudo mais confuso e ambiguo, por vezes mais dificil de debugar tambem.

StarRider

  • Visitante
Re: Embedded Systems - Shape The World com TIVA TM4C123
« Responder #20 em: 28 de Janeiro de 2015, 15:19 »
A única vantagem que advém do uso de libs para aceder aos periféricos é que possibilita a portabilidade entre
MCUs da mesma família e do mesmo fabricante ... e claro que evita quem as usa tenha um conhecimento
mais profundo.

Por norma as Libs fornecidas pelos fabricantes (STM, NXP, TI, etc) têm um overhead estupidamente alto, os
tais assert's ás toneladas nas funções, o aumento dramático do código (e existem limitações de flash em
algumas situações), o próprio overhead da chamada da função e da pré-definição e preenchimento de
estruturas e variáveis antes da chamada à função da Lib, etc, etc.

Existem situações criticas em que simplesmente o recurso a função destas Libs é incomportável, como por
exemplo o uso dentro de rotinas que sirvam interrupções, e em situações em que existem timmings apertados.

Pessoalmente prefiro usar os registos, ou seja, as macros de definição dos mesmos que são fornecidas nos
includes específicos para para MCU, e neste caso a portabilidade apesar de não ser a 100% é muito aceitável.

Por exemplo, inicializar o Timer 1 seria  algo no género:
TIM2->CR1 = (TIM_CounterMode_Up | TIM_CKD_DIV1);
TIM1->ARR = 20;

É compatível com toda a gama da ST, é um acesso directo ao registo e é executado em +-3 ciclos do clock
por linha sem necessidade de passar parâmetros no stack, é simples de entender e de alterar, mas implica
saber o que é o registo ARR e CR1 a as mnemónicas. O equivalente a isto usando a Std Lib da ST seria algo
no género:
TIM_TimeBaseInitTypeDef     TIM_TimeBaseStructure;
TIM_TimeBaseStructure.TIM_Period = 0x0008;
TIM_TimeBaseStructure.TIM_Prescaler = 0x0000;;
TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseStructure.TIM_RepetitionCounter = 0x0000;
TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure);

E dentro da função "TIM_TimeBaseInit" vamos ter mais uma 20 linhas de código e uns 6 asserts :(

Atenção que não estou a desaconselhar o uso das Libs, somente a partilhar a ideia de que o uso destas pode
ter algumas (por vezes grandes) desvantagens em termos de performance e compactação do código.

Abraços,
PA
« Última modificação: 28 de Janeiro de 2015, 15:28 por StarRider »

StarRider

  • Visitante
Re: Embedded Systems - Shape The World com TIVA TM4C123
« Responder #21 em: 28 de Janeiro de 2015, 15:43 »
Calma eu não vou ao cumulo de escrever algo assim:
(APB2PERIPH_BASE + 0x2400) |= 0xFFEC01AD;
 
Seria mais algo no género: *((uint32_t *) (APB2PERIPH_BASE + 0x2400)) |= 0xFFEC01AD

Abraços,
PA



Precisa de levar um casting antes de ser usado como endereço?

Boas Luís,

Sim, segue este raciocínio::
Código: [Seleccione]
#define APB2PERIPH_BASE    ((uint32_t)0x40010000)
uint32_t addr = (APB2PERIPH_BASE + 0x2400);  //"addr" é um int e contem o valor 0x40012400
uint32_t * pointer = addr;  // "pointer" é um ponteiro para um uint32_t que está no endereco 0x40012400
uint32_t valor = *pointer; // deferenciar o "pointer",  "valor" contem o valor da zona de memoria localizada no
endereço 0x40012400

Abraços,
PA
« Última modificação: 28 de Janeiro de 2015, 15:55 por StarRider »