Lab 1 Program C
Fork of mbed by
I2C.h
- Committer:
- rolf.meyer@arm.com
- Date:
- 2009-08-28
- Revision:
- 11:1c1ebd0324fa
- Parent:
- 4:5d1359a283bc
- Child:
- 12:f63353af7be8
File content as of revision 11:1c1ebd0324fa:
/* mbed Microcontroller Library - I2C * Copyright (c) 2007-2009 ARM Limited. All rights reserved. * sford */ #ifndef MBED_I2C_H #define MBED_I2C_H #include "platform.h" #include "PinNames.h" #include "PeripheralNames.h" #include "Base.h" namespace mbed { /* Class: I2C * An I2C Master, used for communicating with I2C slave devices * * Example: * > // Read from I2C slave at address 0x1234 * > * > #include "mbed.h" * > * > I2C i2c(p28, p27); * > * > int main() { * > int address = 0x1234; * > char data[2]; * > i2c.read(address,data,2); * > // ... * > } */ class I2C : public Base { public: /* Constructor: I2C * Create an I2C Master interface, connected to the specified pins * * Variables: * sda - I2C data line pin * scl - I2C clock line pin */ I2C(PinName sda, PinName scl, const char *name = NULL); /* Function: frequency * Set the frequency of the I2C interface * * Variables: * hz - The bus frequency in hertz */ void frequency(int hz); /* Function: read * Read from an I2C slave * * Variables: * address - 7-bit I2C slave address (0-127) * data - Pointer to the byte-array to read data in to * length - Number of bytes to read * returns - 0 on success (ack), or 1 on failure (nack) */ int read(int address, char *data, int length); /* Function: write * Write to an I2C slave * * Variables: * address - 7-bit I2C slave address (0-127) * data - Pointer to the byte-array data to send * length - Number of bytes to send * returns - 0 on success (ack), or 1 on failure (nack) */ int write(int address, const char *data, int length); protected: I2CName _i2c; void aquire(); static I2C *_owner; int _hz; }; } // namespace mbed #endif