Ir ao conteúdo
  • Cadastre-se

Mulder_Fox

Membro Pleno
  • Posts

    4.059
  • Cadastrado em

  • Última visita

Reputação

214

2 Seguidores

  1. Não sei te informar, pois sempre configurei os bits no código.
  2. Este texto foi copiado do "datasheet" do PIC16F628A: "The user will note that address 2007h is beyond the user program memory space. In fact, it belongs to the special configuration memory space (2000h-3FFFh), which can be accessed only during programming. See “PIC16F627A/628A/648A EEPROM Memory Programming Specification” (DS41196) for additional information."
  3. Obrigado, mister nintendo. A nossa recompensa vem de elogios como o seu, que nos anima a continuar a empreitada. Comecei a escrever a parte 9, mas tenho tido pouco tempo livre, por isso deve demorar um pouco.
  4. Sim, Lipextreme. Esses endereços da memória de programa não são usados quando fazemos o desvio no endereço 0000 para depois do fim da rotina de interrupção que começa no endereço 0004. No MPlab, no menu "View", em "Disassembly listing" podemos ver o que será gravado em cada endereço da memória de programa: Na imagem anterior, eu desenhei retângulos vermelhos ao redor dos endereços 0000 e 0004 da memória de programa. Repare que não será gravado nada nos endereços 0001, 0002 e 0003. Comecei a escrever a parte 9 do tutorial. Nela, vou mostrar como produzir três sinais PWM por software cujos ciclos ativos mudam regularmente, porém são diferentes entre si. Esses sinais PWM são usados para acionar um LED RGB. Como a cor aparente do LED é resultante da soma das três cores dele que são: vermelho, verde e azul, ela muda a cada intervalo de tempo, gerando um efeito visual muito interessante e que pode ser usado em decoração. Edit: vtrx, quando comecei a escrever esta resposta, você ainda não havia postado. Sempre pensei que no PIC16F628A, a instrução GOTO ocupasse apenas um endereço de memória e que o destino do desvio constasse na própria instrução. Repare na imagem a seguir que os dois últimos caracteres da instrução correspondem ao endereço de destino e que a instrução GOTO que será gravada no endereço 0009 só ocupa aquele endereço pois, no próximo 000A será gravada outra instrução:
  5. Bom dia, ricardospimentel. O que eu entendo sobre o funcionamento do PIC16F628A é o seguinte: Há a chamada Memória de Programa, onde são gravadas as instruções que compõe o programa. Essa memória começa no endereço 0000 e vai até o endereço 07FF, totalizando 2048 endereços. Há o chamado Contador de Programa onde está escrito qual endereço da memória de programa será acessado para que seja executada a instrução ali contida. Após a execução de uma instrução, o Contador de Programa é incrementado automaticamente. Após um reset, inclusive o power-on reset que ocorre quando o microcontrolador recebe alimentação, o valor do Contador de Programa é igual a 0000 e, portanto, a instrução a ser executada é a gravada no endereço 0000 da Memória de Programa. Após isso, o contador de programa é incrementado e, então, será executada a instrução contida no endereço 0001 da Memória de Programa, depois o contido no endereço 0002 e assim por diante. As interrupções são provocadas pelos periféricos do microcontrolador, que são circuitos "independentes". Elas fazem com que o microcontrolador execute a instrução gravada no endereço 0004 da Memória de Programa, pois, escrevem esse valor no Contador de Programa (ao mesmo tempo que salvam o endereço da Memória de Programa da instrução que seria executada antes da interrupção para que ela possa ser executada após a saída da rotina de interrupção). Então, se o nosso programa não fará uso de nenhuma interrupção, podemos gravá-lo a partir do endereço 0000, passando pelo 0004 sem problemas. Se vamos usar alguma interrupção, devemos gravar a rotina de interrupção a partir do endereço 0004, já que esse é o endereço que será acessado na interrupção. O limite para o tamanho da rotina de interrupção é o tamanho da Memória de Programa. Como as instruções do programa que referem-se à rotina de interrupção devem ser escritas a partir do endereço 0004 da Memória de Programa, o restante do programa é gravado depois do fim da rotina de interrupção, já que não caberia nos quatro endereços que existem antes (0000, 0001, 0002 e 0003). No endereço 0000 da Memória de Programa é gravada uma instrução GOTO que desvia o microcontrolador para depois do fim da rotina de interrupção. O microcontrolador executa apenas uma instrução por vez. Ele não roda dois códigos ao mesmo tempo e não há diferença entre a execução de instruções no programa "principal" ou na rotina de interrupção. É só uma questão do local da Memória de Programa onde as instruções estão gravadas. Você pode simular a execução do programa com o MPlab dentro da rotina de interrupção, colocando um breakpoint onde ela começa. Os Timers não rodam código, eles são circuitos digitais (contadores) que funcionam independentemente da CPU do microcontrolador. Eles podem ser sincronizados com o mesmo sinal de clock da CPU ou com um externo. Posso estar enganado sobre o que escrevi, mas é assim que creio que a "coisa" toda funciona. Segue o link para o manual de referência da família 16 da Microchip: http://ww1.microchip.com/downloads/en/DeviceDoc/33023a.pdf
  6. ricardospimentel, fico feliz por você estar gostando do tutorial. Quando decidi escrever o tutorial, fiz questão de procurar descrever o uso do simulador do MPlab, justamente porque o considero uma ótima ferramenta.
  7. Olá, ricardospimentel. O prazer é meu. O que ocorre é que o incremento somente irá ocorrer quando terminar o "debounce" do botão 1. Para o "debounce" são usadas as variáveis DB1_BTA e DB1_BTB. A primeira inicia com o valor 255 e é decrementada toda vez que a subrotina "TRATA_BOTAO_1" for executada, estando o botão 1 pressionado. Quando ela chega a 0, é reiniciada com o valor 255 e a variável DB1_BTB é decrementada. Essa última é inciada com o valor 20. Quando DB1_BTB houver chegado a 0, o debounce acabou e, então o incremento ocorre. Dessa forma, rotina "TRATA_BOTAO_1" deve ser executada 5.100 vezes (255 x 20) para que ocorra o incremento. O mesmo vale para o botão 2 que faz o decremento. Para o botão 2 são usadas as variáveis DB2_BTA e DB2_BTB. Você pode colocar "breakpoints" para acompanhar passo a passo usando o botão "Run". Coloque um "breakpoint" na seguinte linha para acompanhar a partir do fim do "debounce": INCF UNIDADE,F ;INCREMENTA UNIDADE Edit: Opa! Estava escrevendo ao mesmo tempo que você! Vejo que você já entendeu. De fato, cada vez que você clica no botão "Step Into" o simulador executa uma instrução.
  8. Que bom que você entendeu. Se tiver outra dúvida, estamos aí para tentar esclarecer.
  9. Lipextreme, você não está incomodando, pelo contrário. Sua dúvida me mostrou que não expliquei bem as operações com os registradores. No sistema decimal, cada dezena vale dez unidades e, por isso, quando vamos fazer, por exemplo, a operação 23 - 18, nós decrementamos a dezena do número 23 e somamos dez à sua unidade transformando-a em 13. Daí fazemos 13 - 8, o que resulta em 5. Depois subtraímos as dezenas (1 -1) resultando em 0. O resultado da subtração é portanto 5. No sistema decimal cada algarismo varia de 0 a 9. Repare que se decrementarmos o algarismo 3 oito vezes vamos chegar ao seguinte: 3 - 1 = 2 2 - 1 = 1 1 - 1 = 0 0 - 1 = 9 9 - 1 = 8 8 - 1 = 7 7 - 1 = 6 6 - 1 = 5 No caso dos registradores do programa, cada "unidade" do REG2B vale 256 "unidades" do REG1B. Então se o REG1A for maior do que o REG1B, nós deveríamos decrementar REG2B e somar 256 ao REG1B para fazer a subtração. Mas, nós não precisamos somar 256 ao REG1B, pois, no microcontrolador, a subtração ocorre pelo método do complemento de 2. O resultado obtido é o mesmo que se o REG1B fosse decrementado um número de vezes igual ao valor do REG1A, como no exemplo que dei para o sistema decimal. Vamos supor que o valor de REG1B fosse 128 e o de REG1A, 230. Quando fazemos REG1B = REG1B - REG1A, através da instrução SUBWF, é como se o REG1B fosse decrementado 230 vezes. Após 128 vezes o seu valor seria igual a 0. Na 129ª vez, o seu valor seria igual a 255. Apos 230 vezes, o seu valor seria de 154. Mas, repare que 154 é igual a (128 + 256) - 230 Só lembrando que o microcontrolador não decrementa o REG1B 230 vezes. Ele calcula o complemento de 2 do REG1A e depois soma (isso mesmo: soma) ao REG1B para efetuar a operação de subtração. É por isso que não precisamos somar 256 ao REG1B antes. Foi isso que faltou explicar no tutorial e que gerou a sua dúvida. Espero que tenha sido claro.
  10. Qualquer outra dúvida fique à vontade, Lipextreme. Tive que interromper o tutorial por falta de tempo. Pretendo continuá-lo tão logo seja possível.
  11. Olá, Lipextreme. Desculpe-me pela demora para responder. Estive muito ocupado nos últimos dias. Obrigado pelos elogios. Você deve salvar os registradores W e STATUS qualquer que seja a fonte de interrupção. A razão de salvar os valores desses registradores é que eles são alterados dentro da rotina de interrupção. O que muda quando se usa a interrupção do Timer1 é que deve-se testar se o bit TMR1IF está setado para confirmar que a interrupção foi gerada pelo Timer1 e depois zerá-lo.
  12. Recomendo testar o circuito numa protoboard antes de montá-lo, já que não foi testado antes. Quando desenhei esse circuito desenvolvi também uma placa. Vou procurar aqui nos meus backups.
  13. alderi17, entre montar com CIs e com microcontrolador, o melhor é com microcontrolador. Com CI e para 6 jogadores, basta ampliar o circuito. Não sou profissional.
  14. Sim, essa fonte serve. Sua potência é mais do que suficiente. A rede aí é de 220 V?

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...