logo elektroda
logo elektroda
X
logo elektroda
REKLAMA
REKLAMA
Adblock/uBlockOrigin/AdGuard mogą powodować znikanie niektórych postów z powodu nowej reguły.

[ATTINY85][ASM]Wytłumaczenie zasady działania krótkiego programu

piotrva 10 Kwi 2012 18:34 1534 2
REKLAMA
  • #1 10779417
    piotrva
    VIP Zasłużony dla elektroda
    Drodzy Koledzy!
    Wiem, że to może kolejne bezsensowne pytanie i prośba, która powinna zakończyć się stwierdzeniem "naucz się ASM to sam zrozumiesz albo i nie" albo "lepiej napisać program od początku niż to analizować", ale mimo wszystko chciałbym bardzo prosić osoby znające ASM i dużo bardziej doświadczone ode mnie o wytłumaczenie w punktach zasady działania (wydaje mi się prostego i krótkiego) programu. (jest to kod emulatora tagów RFID na tym procesorze ze strony http://scanlime.org/2008/09/using-an-avr-as-an-rfid-tag/ )
    Z góry bardzo bardzo dziękuję za pomoc.
    Kod: text
    Zaloguj się, aby zobaczyć kod

    Informacje prawne i inne o kodzie:
    
    /*
     * Software-only implementation of a passive low-frequency RFID tag,
     * using an AVR microcontroller.
     *
     * Version 1.1, 2010-06-15
     *
     * Copyright (c) 2008-2010 Micah Dowty <micah@navi.cx>
     * See end of file for license terms. (BSD style)
     * Improved HID modulation contributed by Luke Koops <luke.koops@gmail.com>
     * HID parity bit support contributed by Cesar Fernandez <cex123@gmail.com>
    */
    (program wyżej)
    /*****************************************************************/
     
    /*
     * Permission is hereby granted, free of charge, to any person
     * obtaining a copy of this software and associated documentation
     * files (the "Software"), to deal in the Software without
     * restriction, including without limitation the rights to use,
     * copy, modify, merge, publish, distribute, sublicense, and/or sell
     * copies of the Software, and to permit persons to whom the
     * Software is furnished to do so, subject to the following
     * conditions:
     *
     * The above copyright notice and this permission notice shall be
     * included in all copies or substantial portions of the Software.
     *
     * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
     * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
     * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
     * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
     * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
     * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
     * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
     * OTHER DEALINGS IN THE SOFTWARE.
     */
    
  • REKLAMA
  • Pomocny post
    #2 10784808
    excray
    Poziom 41  
    Żeby zobaczyć "realny asm" trzeba skompilować plik i podejrzeć plik lss:
    Kod: text
    Zaloguj się, aby zobaczyć kod

    Nie chce mi się tego rozpisywać ale generalnie polega to cyklicznym zwieraniu na określony czas cewki podłączonej do pinów PB3 i PB4. Wywołania rcall pod adres 0x230 to właśnie zwieranie cewki a pod adres 0x234 to ponowne rozłączenie. 1 cykl czyli jeden wysyłany bit się składa z dwóch załącz/wyłącz z tym że 0 reprezentuje załącz/wyłącz a 1 wyłącz/załącz (lub odwrotnie :-) czyli transmisja 001 wygląda tak: załącz/wyłącz/załącz/wyłącz/wyłącz/załącz. Generalnie jako że cewka jest również generatorem CLK dla atiny więc jest ona zwierana na 32 cykle nadajnika RFID. Niemniej dziwi mnie sytuacja gdy cewka jest zwarta a więc atiny teoretycznie nie ma sygnału clk i nie powinien już wyjść z tego stanu zawieszając się na amen.
  • #3 10785013
    piotrva
    VIP Zasłużony dla elektroda
    Witaj, dzięki wielkie za odpowiedź, wczoraj właśnie późnym wieczorem sam to rozpracowałem, że jedyne co robi program to w odpowiednich przedziałach czasowych (co 32 cykle, czyli czas trwania półbitu w tym przypadku) załącza lub wyłącza rezystory podciągające zgodnie z kodowaniem manchester kodu który ma być nadawany. Myślę, że kluczem do tego że procesor się nie "wyłącza/zawiesza" może być:
    1. kondensator 100nF równolegle z cewką
    2. "zwieranie cewki" przez pull-upy
    Mimo wszystko potwierdzam że projekt ten i oprogramowanie w 100% działa i spełnia swoja funkcję.
    Jeszcze raz dzięki za wyjaśnienie, temat uważam za wyczerpany i zamknięty, teraz kolej na implementację tego na procesorze z własnym zasilaniem i taktowaniem o kilka rzędów wielkości wyższym niż częstotliwość nośna i to w C.
REKLAMA