- 26 May, 2021 1 commit
-
-
Alexander Entinger authored
-
- 25 May, 2021 1 commit
-
-
Alexander Entinger authored
Declare TwoWire functions as virtual
-
- 25 Feb, 2021 1 commit
-
-
ArkadyGamza authored
To make alternative implementations of the TwoWire class (e.g. SoftwareWire for software I2C) work properly being passed to libraries that expect TwoWire type.
-
- 12 Jan, 2021 1 commit
-
-
Martino Facchin authored
fix twi_manageTimeoutFlag function description
-
- 09 Jan, 2021 1 commit
-
-
Greyson Christoforo authored
-
- 02 Nov, 2020 3 commits
-
-
Martino Facchin authored
Update platform specification URLs in configuration files
-
per1234 authored
The Google Code URL in boards.txt is very outdated. The URL in platform.txt is to a more recent home of the content, which has been replaced with a link to the new location, but while I'm updating boards.txt, I might as well point both URLs to the real page.
-
Martino Facchin authored
Improve reading ADC result
-
- 01 Nov, 2020 1 commit
-
-
Vitaly Shmagun authored
7.3.0-atmel3.6.1-arduino7 gcc fails to optimize separate reading from ADCL and ADCH. It produces additionally three eor commands or in some cases two mov commands in the assembly code (see discussion #344). These commands swap register contents before store them to data area. So they are completely unnecessary. Reading ADC result with ADC macro fixes it and gcc generates the right code..
-
- 15 Oct, 2020 1 commit
-
-
Martino Facchin authored
Improve and complete implementation of new/delete
-
- 17 Sep, 2020 8 commits
-
-
Matthijs Kooijman authored
The standard dictates that `std::size_t` is used, rather than the plain `size_t` type. Even though these types are usually, if not always, exactly the same type, other code might assume that `std::size_t` is actually used and thus also available under that name after including `<new>`. This fixes that by using the right type. One challenge is that it is usually declared in headers that we do not have available, so this just defines the `std::size_t` type in the `<new>` header to work around that.
-
Matthijs Kooijman authored
This is currently disabled, keeping the old behavior of returning NULL on failure, but should probably be enabled in the future as code that does want to do a null check has had a chance to switch to the more portable nothrow versions. When enabled, allocation failure calls the weak `std::terminate()`, which calls `abort()` by default, but can be replaced by user code to do more specific handling. To enable this, a macro must be defined (in new.cpp or on the compiler commandline). This fixes part of #287.
-
Matthijs Kooijman authored
This fixes part of #287.
-
Matthijs Kooijman authored
These are special functions that are presumably put into vtables for deleted or pure virtual functions. Previously, this would call `abort()` directly, but calling `std::terminate()` achieves the same effect, but allows user code to change the behavior (e.g. to print to serial, blink leds or whatever makes sense).
-
Matthijs Kooijman authored
This allows calling it from other places later. The default implementation calls `abort()`, but making it weak allows user code to override this function (either directly, or by including a library like uclibc++ that implements `std::set_terminate()`). Note that this does not add a declaration for this function, since the standard dictates this to be in `<exception>`, but we cannot meaningfully or completely implement that header, so better leave it to be overridden by e.g. libraries like uclibc++.
-
Matthijs Kooijman authored
This makes these functions weak, so that a sketch or library can replace them. This does not apply to all of these operators, only for the ones that the C++ standard specifies as replaceable.
-
Matthijs Kooijman authored
This makes this header complete up to including C++14, except two exception classes that cannot be defined without `<exception>`. The functions related to the "new_handler" are declared but not actually defined, to prevent overhead and complexity. They are still declared to allow implementing them in user code if needed. This makes the implementation of all operator new and delete functions comply with the C++11/C++14 specification in terms of which should be actually implemented and which should be delegate to other functions. There are still some areas where these implementations are not entirely standards-compliant, which will be fixed in subsequent commits. This fixes part of #287 and fixes #47.
-
Matthijs Kooijman authored
Originally, the Arduino core used "new.h", rather than the standard "new", probably because the implementation was incomplete, and for the most commonly used new and delete operators, no include is needed at all (they are defined implicitly by the compiler). However, now Arduino does expose the "new" name, as an alias for the older "new.h". Given that the standard name is "new", it makes more sense to put the actual content in "new", and make "new.h" a compatibility header that includes "new" instead of the other way around.
-
- 11 Jun, 2020 7 commits
-
-
Martino Facchin authored
-
Martino Facchin authored
-
Matthijs Kooijman authored
-
Martino Facchin authored
-
Greyson Christoforo authored
move timout handling into its own function change timeout from milliseconds to microseconds don't forget operating slave address or the bitrate when we reset because of a timeout Co-Authored-By: Witold Markowski <witold.a.markowski@gmail.com> fix delay datatype uint16_t --> uint32_t Update libraries/Wire/src/utility/twi.c fix mix up using TWBR instea of TWAR! Co-Authored-By: Matthijs Kooijman <matthijs@stdin.nl> Update libraries/Wire/src/utility/twi.c fix 2nd TWBR/TWAR mixup Co-Authored-By: Matthijs Kooijman <matthijs@stdin.nl> twi_stop() should use the same timeout as everywhere else all while loops are now protected by timeouts Revert "twi_stop() should use the same timeout as everywhere else" This reverts commit 68fe5f1dae1bb41183bb37eeda3fb453394a580c. make timeout counter volatile rename timeout function for improved clarity - resetting the twi interface on timeouts is now optional - timeouts in the ISR are no longer hardcoded and now obey the set timeout value - a user-readable flag is now set whenever a timeout occurs - the user can clear this flag whenever they like
-
Martino Facchin authored
Add "new" proxy header for compatibility with c++-standard #include<new>
-
Martino Facchin authored
Added precompiled library support
-
- 13 May, 2020 1 commit
-
-
eudoxos authored
-
- 04 May, 2020 1 commit
-
-
Martino Facchin authored
Correct comment on wiring_analog.c
-
- 02 May, 2020 1 commit
-
-
Maximilian Leopold authored
-
- 28 Apr, 2020 1 commit
-
-
Cristian Maglie authored
-
- 19 Mar, 2020 1 commit
-
-
Martino Facchin authored
Fix sine -> since typo in HardwareSerial files
-
- 18 Mar, 2020 1 commit
-
-
Daniel Jackson authored
-
- 02 Dec, 2019 1 commit
-
-
Cristian Maglie authored
-
- 25 Sep, 2019 1 commit
-
-
Manuel Reimer authored
* Interrupt ordering for 32u2 and 16u2 MCU * Added missing chip variants
-
- 20 Sep, 2019 3 commits
-
-
Giampiero Baggiani authored
Port of https://github.com/arduino/Arduino/pull/7023
-
Martino Facchin authored
Remove Genuino Occurrences
-
Cristian Maglie authored
-
- 19 Sep, 2019 1 commit
-
-
Luca Cipriani authored
-
- 18 Sep, 2019 2 commits
-
-
Alexander Entinger authored
Revert "Changed linking order, so precompiled libraries can be used"
-
Alexander Entinger authored
This reverts commit 41f15a13.
-
- 16 Sep, 2019 1 commit
-
-
Alexander Entinger authored
No fixed value for USB power current.
-