📄 avrhardware.h
字号:
/* tab:4 * * * "Copyright (c) 2000-2002 The Regents of the University of California. * All rights reserved. * * Permission to use, copy, modify, and distribute this software and its * documentation for any purpose, without fee, and without written agreement is * hereby granted, provided that the above copyright notice, the following * two paragraphs and the author appear in all copies of this software. * * IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT * OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF * CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES, * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY * AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS * ON AN "AS IS" BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATION TO * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS." * *//* tab:4 * IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING. By * downloading, copying, installing or using the software you agree to * this license. If you do not agree to this license, do not download, * install, copy or use the software. * * Intel Open Source License * * Copyright (c) 2002 Intel Corporation * All rights reserved. * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * Neither the name of the Intel Corporation nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE INTEL OR ITS * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * *//* * * Authors: Jason Hill, Philip Levis, Nelson Lee * * */#ifndef TOSH_AVRHARDWARE_H#define TOSH_AVRHARDWARE_H#include <io.h>#include <sig-avr.h>#include <interrupt.h>#include <wdt.h>#define TOSH_ASSIGN_PIN(name, port, bit) \static inline void TOSH_SET_##name##_PIN() {sbi(PORT##port , bit);} \static inline void TOSH_CLR_##name##_PIN() {cbi(PORT##port , bit);} \static inline char TOSH_READ_##name##_PIN() {return 0x01 & (inp(PIN##port) >> bit);} \static inline void TOSH_MAKE_##name##_OUTPUT() {sbi(DDR##port , bit);} \static inline void TOSH_MAKE_##name##_INPUT() {cbi(DDR##port , bit);} #define TOSH_ASSIGN_OUTPUT_ONLY_PIN(name, port, bit) \static inline void TOSH_SET_##name##_PIN() {sbi(PORT##port , bit);} \static inline void TOSH_CLR_##name##_PIN() {cbi(PORT##port , bit);} \static inline void TOSH_MAKE_##name##_OUTPUT() {;} #define TOSH_ALIAS_OUTPUT_ONLY_PIN(alias, connector)\static inline void TOSH_SET_##alias##_PIN() {TOSH_SET_##connector##_PIN();} \static inline void TOSH_CLR_##alias##_PIN() {TOSH_CLR_##connector##_PIN();} \static inline void TOSH_MAKE_##alias##_OUTPUT() {} \#define TOSH_ALIAS_PIN(alias, connector) \static inline void TOSH_SET_##alias##_PIN() {TOSH_SET_##connector##_PIN();} \static inline void TOSH_CLR_##alias##_PIN() {TOSH_CLR_##connector##_PIN();} \static inline char TOSH_READ_##alias##_PIN() {return TOSH_READ_##connector##_PIN();} \static inline void TOSH_MAKE_##alias##_OUTPUT() {TOSH_MAKE_##connector##_OUTPUT();} \static inline void TOSH_MAKE_##alias##_INPUT() {TOSH_MAKE_##connector##_INPUT();} // We need slightly different defs than SIGNAL, INTERRUPT#define TOSH_SIGNAL(signame) \void signame() __attribute__ ((signal, spontaneous, C))#define TOSH_INTERRUPT(signame) \void signame() __attribute__ ((interrupt, spontaneous, C))/* Watchdog Prescaler */enum { TOSH_period16 = 0x00, // 47ms TOSH_period32 = 0x01, // 94ms TOSH_period64 = 0x02, // 0.19s TOSH_period128 = 0x03, // 0.38s TOSH_period256 = 0x04, // 0.75s TOSH_period512 = 0x05, // 1.5s TOSH_period1024 = 0x06, // 3.0s TOSH_period2048 = 0x07 // 6.0s};void TOSH_wait(){ asm volatile("nop"); asm volatile("nop");}void TOSH_sleep(){ sbi(MCUCR, 5); //sbi(MCUCR, SE); asm volatile ("sleep");}/** * (Busy) wait <code>usec</code> microseconds */inline void TOSH_uwait(uint16_t usec){ /* In most cases (constant arg), the test is elided at compile-time */ if (usec) /* loop takes 4 cycles, aka 1us */ asm volatile ("1: sbiw %0,1\n"" brne 1b" : "+r" (usec));}#endif //TOSH_AVRHARDWARE_H
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -