# Copyright 2021 The Pigweed Authors # # Licensed under the Apache License, Version 2.0 (the "License"); you may not # use this file except in compliance with the License. You may obtain a copy of # the License at # # https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations under # the License. import("//build_overrides/pigweed.gni") import("$dir_pw_build/target_types.gni") import("$dir_pw_chrono/backend.gni") import("$dir_pw_docgen/docs.gni") import("$dir_pw_unit_test/test.gni") config("public_include_path") { include_dirs = [ "public" ] visibility = [ ":*" ] } config("backend_config") { include_dirs = [ "public_overrides" ] visibility = [ ":*" ] } # This target provides the backend for pw::sync::InterruptSpinLock. # The provided implementation makes a single attempt to acquire the lock and # asserts if it is unavailable. It does not perform interrupt masking or disable # global interrupts, so this implementation does not support simultaneous # multi-threaded environments including IRQs, and is only meant to prevent # data corruption. This implementation is not yet set up to support hardware # multi-threading (SMP, SMT, etc). pw_source_set("interrupt_spin_lock") { public_configs = [ ":public_include_path", ":backend_config", ] public = [ "public/pw_sync_baremetal/interrupt_spin_lock_inline.h", "public/pw_sync_baremetal/interrupt_spin_lock_native.h", "public_overrides/pw_sync_backend/interrupt_spin_lock_inline.h", "public_overrides/pw_sync_backend/interrupt_spin_lock_native.h", ] public_deps = [ "$dir_pw_assert", "$dir_pw_sync:interrupt_spin_lock.facade", "$dir_pw_sync:yield_core", ] } # This target provides the backend for pw::sync::Mutex. # The provided implementation makes a single attempt to acquire the lock and # asserts if it is unavailable. This implementation is not yet set up to support # hardware multi-threading (SMP, SMT, etc). pw_source_set("mutex") { public_configs = [ ":public_include_path", ":backend_config", ] public = [ "public/pw_sync_baremetal/mutex_inline.h", "public/pw_sync_baremetal/mutex_native.h", "public_overrides/pw_sync_backend/mutex_inline.h", "public_overrides/pw_sync_backend/mutex_native.h", ] public_deps = [ "$dir_pw_assert", "$dir_pw_sync:mutex.facade", ] } # This target provides the backend for pw::sync::RecursiveMutex. # The provided implementation makes a single attempt to acquire the lock and # asserts if it is unavailable. This implementation is not yet set up to support # hardware multi-threading (SMP, SMT, etc). pw_source_set("recursive_mutex") { public_configs = [ ":public_include_path", ":backend_config", ] public = [ "public/pw_sync_baremetal/recursive_mutex_inline.h", "public/pw_sync_baremetal/recursive_mutex_native.h", "public_overrides/pw_sync_backend/recursive_mutex_inline.h", "public_overrides/pw_sync_backend/recursive_mutex_native.h", ] public_deps = [ "$dir_pw_assert", "$dir_pw_sync:recursive_mutex.facade", ] visibility = [ "$dir_pw_sync:*" ] } pw_doc_group("docs") { sources = [ "docs.rst" ] } pw_test_group("tests") { }