Skip to content

Commit

Permalink
build(bazel): always build with TF_LITE_STATIC_MEMORY
Browse files Browse the repository at this point in the history
Add TF_LITE_STATIC_MEMORY to the defines set globally for TFLM builds in
Bazel. TFLM always builds with this set in Make, and it appears to have
been an oversight that it wasn't set during Bazel builds. Not having it
set in Bazel caused some unit tests to pass under Bazel that failed
under Make.

At the same time, add -fno-exceptions. This flag is also always set in
Make builds. Without it, setting TF_LITE_STATIC_MEMORY breaks the build.
TF_LITE_STATIC_MEMORY triggers TF_LITE_REMOVE_VIRTUAL_DELETE in
t/l/m/compatibility.h, which makes operator delete private in certain
classes. When exceptions are enabled, a placement new with those classes
is allowed to throw an exception, and operator delete is implicitly
called during the unwind. The build breaks because operator delete can't
be called if it's private. Disabling exceptions eliminates the unwind
code that calls operator delete implicitly, and thus the build succeeds.

In any case, -fno-exceptions should have been used in Bazel builds,
matching the flags used in Make and the no-exceptions design requirement
of the TFLM project.
  • Loading branch information
rkuester committed Oct 17, 2024
1 parent 1eb4e0d commit 7b3a2bd
Showing 1 changed file with 4 additions and 1 deletion.
5 changes: 4 additions & 1 deletion tensorflow/lite/micro/build_def.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,17 @@ def tflm_copts():
be useful when additively overriding the defaults for a particular target.
"""
return [
"-fno-exceptions",
"-Wall",
"-Wno-unused-parameter",
"-Wnon-virtual-dtor",
"-DFLATBUFFERS_LOCALE_INDEPENDENT=0",
]

def tflm_defines():
return select({
return [
"TF_LITE_STATIC_MEMORY=1",
] + select({
"//:with_compression_enabled": ["USE_TFLM_COMPRESSION=1"],
"//conditions:default": [],
})
Expand Down

0 comments on commit 7b3a2bd

Please sign in to comment.