SPDX-License-Identifier: CC-BY-SA-4.0 OR BSD-2-Clause copyrights: - Copyright (C) 2021 embedded brains GmbH & Co. KG enabled-by: true links: - role: requirement-refinement uid: perf-runtime - role: runtime-measurement-request uid: ../val/perf non-functional-type: performance-runtime params: {} rationale: null references: [] requirement-type: non-functional test-body: brief: | Send two events. Satisfy the event condition. code: | ctx->begin = T_tick(); ctx->status = rtems_event_send( ctx->worker_id, EVENT_END | EVENT_OTHER ); description: null test-cleanup: null test-prepare: null test-setup: null test-teardown: brief: | Set the measured runtime. Discard samples interrupted by a clock tick. code: | T_quiet_rsc_success( ctx->status ); *delta = ctx->end - ctx->begin; return tic == toc; description: null text: | Let U and V be two tasks with the same home scheduler. Let :math:`B` be a time point measured by U right before a call to ${../if/send:/name} which does satisfy the event condition of the waiting task V which does preempt the caller. Let :math:`E` be a time point measured by V right after the first context switch after :math:`B`. While the execution environment is ${.:/environment}, while the task V waits for events, while the measurement sample is :math:`E - B`, when exactly ${../val/perf:/params/sample-count} samples are collected, the ${.:/limit-kind} shall be ${.:/limit-condition}. type: requirement