diff --git a/clang/lib/Basic/Targets/AVR.cpp b/clang/lib/Basic/Targets/AVR.cpp --- a/clang/lib/Basic/Targets/AVR.cpp +++ b/clang/lib/Basic/Targets/AVR.cpp @@ -384,6 +384,9 @@ auto It = llvm::find_if( AVRMcus, [&](const MCUInfo &Info) { return Info.Name == this->CPU; }); + if (It->IsTiny) + Builder.defineMacro("__AVR_TINY__", "1"); + if (It != std::end(AVRMcus)) { Builder.defineMacro(It->DefineName); if (It->NumFlashBanks >= 1) diff --git a/clang/test/Preprocessor/avr-common.c b/clang/test/Preprocessor/avr-common.c --- a/clang/test/Preprocessor/avr-common.c +++ b/clang/test/Preprocessor/avr-common.c @@ -1,6 +1,11 @@ -// RUN: %clang_cc1 -E -dM -triple avr-unknown-unknown /dev/null | FileCheck -match-full-lines %s +// RUN: %clang_cc1 -E -dM -triple avr-unknown-unknown -target-cpu attiny13 /dev/null | FileCheck -match-full-lines --check-prefixes=CHECK,AVR %s +// RUN: %clang_cc1 -E -dM -triple avr-unknown-unknown -target-cpu attiny4 /dev/null | FileCheck -match-full-lines --check-prefixes=CHECK,TINY %s // CHECK: #define AVR 1 // CHECK: #define __AVR 1 + +// TINY: #define __AVR_TINY__ 1 +// AVR-NOT: __AVR_TINY__ + // CHECK: #define __AVR__ 1 // CHECK: #define __ELF__ 1