twi_slave.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /**
  2. * \file
  3. *
  4. * \brief TWI Slave Mode management
  5. *
  6. * Copyright (c) 2010-2015 Atmel Corporation. All rights reserved.
  7. *
  8. * \asf_license_start
  9. *
  10. * \page License
  11. *
  12. * Redistribution and use in source and binary forms, with or without
  13. * modification, are permitted provided that the following conditions are met:
  14. *
  15. * 1. Redistributions of source code must retain the above copyright notice,
  16. * this list of conditions and the following disclaimer.
  17. *
  18. * 2. Redistributions in binary form must reproduce the above copyright notice,
  19. * this list of conditions and the following disclaimer in the documentation
  20. * and/or other materials provided with the distribution.
  21. *
  22. * 3. The name of Atmel may not be used to endorse or promote products derived
  23. * from this software without specific prior written permission.
  24. *
  25. * 4. This software may only be redistributed and used in connection with an
  26. * Atmel microcontroller product.
  27. *
  28. * THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED
  29. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  30. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
  31. * EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR
  32. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  33. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  34. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  35. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  36. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
  37. * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  38. * POSSIBILITY OF SUCH DAMAGE.
  39. *
  40. * \asf_license_stop
  41. *
  42. */
  43. /*
  44. * Support and FAQ: visit <a href="http://www.atmel.com/design-support/">Atmel Support</a>
  45. */
  46. #ifndef TWI_SLAVE_H_INCLUDED
  47. #define TWI_SLAVE_H_INCLUDED
  48. #include <parts.h>
  49. #include <compiler.h>
  50. #if (SAM3S || SAM3U || SAM3N || SAM3XA || SAM4S || SAM4E || SAM4N || SAM4C || SAM4CM || SAMG || SAM4CP)
  51. # include "sam_twi/twi_slave.h"
  52. #elif XMEGA
  53. # include "xmega_twi/twi_slave.h"
  54. #elif MEGA_RF
  55. # include "megarf_twi/twi_slave.h"
  56. #elif (defined(__GNUC__) && defined(__AVR32__)) || (defined(__ICCAVR32__) || defined(__AAVR32__))
  57. #if (defined AVR32_TWI)
  58. #error Not supported.
  59. #endif
  60. #else
  61. # error Unsupported chip type
  62. #endif
  63. /**
  64. *
  65. * \defgroup twi_group Two Wire-interface(TWI)
  66. *
  67. * This is the common API for TWIs. Additional features are available
  68. * in the documentation of the specific modules.
  69. *
  70. * \section twi_group_platform Platform Dependencies
  71. *
  72. * The twi API is partially chip- or platform-specific. While all
  73. * platforms provide mostly the same functionality, there are some
  74. * variations around how different bus types and clock tree structures
  75. * are handled.
  76. *
  77. * The following functions are available on all platforms, but there may
  78. * be variations in the function signature (i.e. parameters) and
  79. * behaviour. These functions are typically called by platform-specific
  80. * parts of drivers, and applications that aren't intended to be
  81. * portable:
  82. * - twi_slave_setup()
  83. * - twi_slave_enable()
  84. * - twi_slave_disable()
  85. * - twi_slave_read()
  86. * - twi_slave_write()
  87. *
  88. * @{
  89. */
  90. /**
  91. * \typedef twi_slave_t
  92. * This type can be used independently to refer to TWI slave module for the
  93. * architecture used. It refers to the correct type definition for the
  94. * architecture, ie. TWI_t* for XMEGA or avr32_twi_t* for UC3
  95. */
  96. //! @}
  97. #endif /* TWI_SLAVE_H_INCLUDED */