Subversion Repositories idreammicro-avr

Rev

Rev 2 | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

/**************************************************************************//**
 * \brief Digital I/O library - Demonstration program
 * \author Copyright (C) 2011  Julien Le Sech - www.idreammicro.com
 * \version 1.0
 * \date 20090314
 *
 * This file is part of the iDreamMicro library.
 *
 * This library is free software: you can redistribute it and/or modify it under
 * the terms of the GNU Lesser General Public License as published by the Free
 * Software Foundation, either version 3 of the License, or (at your option) any
 * later version.
 *
 * This library is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
 * details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program. If not, see http://www.gnu.org/licenses/
 ******************************************************************************/


/**************************************************************************//**
 * \file digital_io__demo.c
 ******************************************************************************/


/******************************************************************************
 * Header file inclusions.
 ******************************************************************************/


#include "../digital_io.h"

#include <avr/io.h>
#include <util/delay.h>

/******************************************************************************
 * Main function.
 ******************************************************************************/


/**************************************************************************//**
 * \fn int main(void)
 *
 * \brief Main function.
 ******************************************************************************/

int
main
(
    void
){
    // Declare pin.
    digital_io__pin_position_t pin = DIGITAL_IO__PORT_B | DIGITAL_IO__PIN_5;
   
    // Configure pin as output.
    digital_io__configure_pin(pin, DIGITAL_IO__DIRECTION__OUTPUT);

    for (;;)
    {
        // Set pin level.
        digital_io__set_pin_level(pin, DIGITAL_IO__LEVEL__HIGH);
        _delay_ms(1000);

        // Reset pin level.
        digital_io__set_pin_level(pin, DIGITAL_IO__LEVEL__LOW);
        _delay_ms(1000);
    }

    return 0;
}