/Zephyr-latest/doc/kernel/services/data_passing/ |
D | fifos.rst | 6 A :dfn:`FIFO` is a kernel object that implements a traditional 7 first in, first out (FIFO) queue, allowing threads and ISRs 17 Any number of FIFOs can be defined (limited only by available RAM). Each FIFO is 20 A FIFO has the following key properties: 25 A FIFO must be initialized before it can be used. This sets its queue to empty. 27 FIFO data items must be aligned on a word boundary, as the kernel reserves 36 FIFO data items are restricted to single active instance across all FIFO 37 data queues. Any attempt to re-add a FIFO data item to a queue before 41 A data item may be **added** to a FIFO by a thread or an ISR. 43 otherwise the item is added to the FIFO's queue. [all …]
|
/Zephyr-latest/tests/kernel/fifo/fifo_api/src/ |
D | test_fifo_contexts.c | 14 struct k_fifo fifo; variable 26 /**TESTPOINT: fifo put*/ in tfifo_put() 30 /**TESTPOINT: fifo put list*/ in tfifo_put() 37 /**TESTPOINT: fifo put slist*/ in tfifo_put() 50 /*get fifo data from "fifo_put"*/ in tfifo_get() 52 /**TESTPOINT: fifo get*/ in tfifo_get() 56 /*get fifo data from "fifo_put_list"*/ in tfifo_get() 61 /*get fifo data from "fifo_put_slist"*/ in tfifo_get() 90 /**TESTPOINT: thread-thread data passing via fifo*/ in tfifo_thread_thread() 102 /**TESTPOINT: isr-thread data passing via fifo*/ in tfifo_thread_isr() [all …]
|
D | test_fifo_loop.c | 14 static struct k_fifo fifo; variable 21 /**TESTPOINT: fifo put*/ in tfifo_put() 31 /*get fifo data from "fifo_put"*/ in tfifo_get() 33 /**TESTPOINT: fifo get*/ in tfifo_get() 42 TC_PRINT("isr fifo get\n"); in tIsr_entry() 44 TC_PRINT("isr fifo put ---> "); in tIsr_entry() 50 TC_PRINT("thread fifo get\n"); in tThread_entry() 53 TC_PRINT("thread fifo put ---> "); in tThread_entry() 58 /* fifo read write job */ 62 /**TESTPOINT: thread-isr-thread data passing via fifo*/ in tfifo_read_write() [all …]
|
D | test_fifo_fail.c | 17 * @brief Test FIFO get fail 24 static struct k_fifo fifo; in ZTEST() local 26 k_fifo_init(&fifo); in ZTEST() 27 /**TESTPOINT: fifo get returns NULL*/ in ZTEST() 28 zassert_is_null(k_fifo_get(&fifo, K_NO_WAIT), NULL); in ZTEST() 29 zassert_is_null(k_fifo_get(&fifo, TIMEOUT), NULL); in ZTEST()
|
/Zephyr-latest/tests/benchmarks/latency_measure/src/ |
D | fifo.c | 8 * @file measure time for various FIFO operations 11 * FIFO operations from both kernel threads and user threads: 12 * 1. Immediately adding a data item to a FIFO 13 * 2. Immediately removing a data item from a FIFO 14 * 3. Immediately adding a data item to a FIFO with allocation 15 * 4. Immediately removing a data item from a FIFO with allocation 16 * 5. Blocking on removing a data item from a FIFO 17 * 6. Waking (and context switching to) a thread blocked on a FIFO via 19 * 7. Waking (and context switching to) a thread blocked on a FIFO via 30 static K_FIFO_DEFINE(fifo); [all …]
|
/Zephyr-latest/tests/kernel/fifo/fifo_timeout/src/ |
D | main.c | 16 * @brief Test fifo APIs timeout 18 * This module tests following fifo timeout scenarios 24 * of queueing/dequeueing when timeout occurs, first on one fifo, then on 27 * Finally, multiple threads pend on one fifo, and they all get the 44 struct k_fifo *fifo; member 112 /* a thread sleeps then puts data on the fifo */ 121 /* a thread pends on a fifo then times out */ 131 packet = k_fifo_get(d->fifo, K_MSEC(d->timeout)); in test_thread_pend_and_timeout() 165 LOG_DBG(" thread (q order: %d, t/o: %d, fifo %p)", in test_multiple_threads_pending() 166 data->q_order, data->timeout, data->fifo); in test_multiple_threads_pending() [all …]
|
/Zephyr-latest/drivers/i2c/ |
D | i2c_xilinx_axi.h | 22 REG_TX_FIFO = 0x108, /* Transmit FIFO */ 23 REG_RX_FIFO = 0x10C, /* Receive FIFO */ 25 REG_TX_FIFO_OCY = 0x114, /* Transmit FIFO Occupancy */ 26 REG_RX_FIFO_OCY = 0x118, /* Receive FIFO Occupancy */ 28 REG_RX_FIFO_PIRQ = 0x120, /* Receive FIFO Programmable Depth Interrupt */ 48 ISR_TX_HALF_EMPTY = BIT(7), /* Transmit FIFO Half Empty */ 52 ISR_RX_FIFO_FULL = BIT(3), /* Receive FIFO Full */ 53 ISR_TX_FIFO_EMPTY = BIT(2), /* Transmit FIFO Empty */ 70 CR_TX_FIFO_RST = BIT(1), /* Transmit FIFO Reset */ 76 SR_TX_FIFO_EMPTY = BIT(7), /* Transmit FIFO empty */ [all …]
|
/Zephyr-latest/dts/bindings/serial/ |
D | infineon,xmc4xxx-uart.yaml | 34 fifo-start-offset: 36 Each USIC0..2 has a fifo that is shared between two channels. For example, 37 usic0ch0 and usic0ch1 will share the same fifo. This parameter defines an offset 38 where the tx and rx fifos will start. When sharing the fifo, the user must properly 39 define the offset based on the configuration of the other channel. The fifo has a 40 capacity of 64 entries. The tx/rx fifos are created on fifo-xx-size aligned 46 fifo-tx-size: 48 Fifo size used for buffering transmit bytes. A value of 0 implies that 49 the fifo is not used while transmitting. transmitting. If the UART is used in async mode 50 then fifo-tx-size should be set to 0. [all …]
|
D | zephyr,nus-uart.yaml | 9 tx-fifo-size: 13 Size of the virtual UART TX FIFO 15 rx-fifo-size: 19 Size of the virtual UART RX FIFO
|
D | zephyr,cdc-acm-uart.yaml | 13 tx-fifo-size: 17 Size of the virtual CDC ACM UART TX FIFO 19 rx-fifo-size: 23 Size of the virtual CDC ACM UART RX FIFO
|
D | zephyr,uart-emul.yaml | 11 tx-fifo-size: 15 Size of the virtual UART TX FIFO 17 rx-fifo-size: 21 Size of the virtual UART RX FIFO
|
D | altr,jtag-uart.yaml | 11 write-fifo-depth: 15 Buffer size of transmit fifo. This used to implement irq_tx_complete. 16 Must be same as Write FIFO: Buffer depth (bytes) in platform designer.
|
/Zephyr-latest/dts/bindings/dai/ |
D | nxp,dai-esai.yaml | 21 tx-fifo-watermark: 25 FIFO. This value needs to be in FIFO words (NOT BYTES). This 28 the TX FIFO watermark will be set to DEFAULT_FIFO_DEPTH / 2. 29 rx-fifo-watermark: 33 FIFO. This values needs to be in FIFO words (NOT BYTES). This 36 the RX FIFO watermark will be set to DEFAULT_FIFO_DEPTH / 2. 37 fifo-depth: 40 Use this property to set the FIFO depth that will be reported 44 we mean the actual (hardware) value of the FIFO depth. This is needed 47 Generally, reporting a false FIFO depth should be avoided. Please note [all …]
|
D | nxp,dai-sai.yaml | 21 rx-fifo-watermark: 25 FIFO. This value needs to be in FIFO words (NOT BYTES). This 28 tx-fifo-watermark: 32 FIFO. This value needs to be in FIFO words (NOT BYTES). This 37 fifo-depth: 40 Use this property to set the FIFO depth that will be reported 45 the FIFO depth. This is needed because some applications (e.g: SOF) 48 FIFO depth should be avoided. Please note that the sanity check 49 for tx/rx-fifo-watermark uses DEFAULT_FIFO_DEPTH instead of this
|
/Zephyr-latest/dts/bindings/usb/ |
D | renesas,smartbond-usbd.yaml | 22 fifo-read-threshold: 25 RX FIFO is 64 bytes. When endpoint size is greater then 64, 26 FIFO warning interrupt is enabled to allow read incoming data 30 possible and when FIFO is hardly filled exit interrupt handler 31 waiting for next FIFO warning level interrupt or packet end. 32 When running at 96MHz code that reads FIFO based on number of 34 fill FIFO with two additional bytes.
|
/Zephyr-latest/dts/bindings/dma/ |
D | gd,gd32-dma-v1.yaml | 5 GD32 DMA controller with FIFO 48 fifo-threshold: A 32bit bitfield value specifying FIFO threshold 49 - bit 0-1: Depth of DMA's FIFO used by burst-transfer. 77 The fifo-threshold cell that places the fourth is configuring FIFO threshold. 79 burst-length in the dma_config struct, and fifo-threshold. 80 A single burst transfer transfers [(4 * fifo-threshold)] bytes using with DMA's FIFO. 83 If the fifo-threshold is a 2-word case, it runs one burst transfer to transfer 8 bytes. 84 Or the fifo-threshold is a 4-word case, runs two times burst transfer to transferring 8 bytes each 99 - fifo-threshold
|
/Zephyr-latest/tests/kernel/fifo/fifo_usage/src/ |
D | main.c | 9 * @brief Use fifo API's in different scenarios 14 * Test Thread enters items into a fifo, starts the Child Thread 16 * the fifo and enters some items back into the fifo. Child Thread 18 * is returned back to Test Thread, it extracts all items from the fifo. 49 /* Data to put into FIFO */ 63 /* Put items into fifo */ in tIsr_entry_put() 75 /* Get items from fifo */ in tIsr_entry_get() 88 /* Get items from fifo */ in thread_entry_fn_single() 94 /* Put items into fifo */ in thread_entry_fn_single() 136 * @brief Tests single fifo get and put operation in thread context [all …]
|
/Zephyr-latest/tests/benchmarks/latency_measure/ |
D | README.rst | 19 * Time it takes to add data to a fifo.LIFO 20 * Time it takes to retrieve data from a fifo.LIFO 21 * Time it takes to wait on a fifo.lifo.(and context switch) 22 * Time it takes to wake and switch to a thread waiting on a fifo.LIFO 70 …fifo.put.immediate.kernel - Add data to FIFO (no ctx switch) : … 71 …fifo.get.immediate.kernel - Get data from FIFO (no ctx switch) : … 72 …fifo.put.alloc.immediate.kernel - Allocate to add data to FIFO (no ctx switch) : … 73 …fifo.get.free.immediate.kernel - Free when getting data from FIFO (no ctx switch) : … 74 …fifo.get.blocking.k_to_k - Get data from FIFO (w/ ctx switch) : … 75 …fifo.put.wake+ctx.k_to_k - Add data to FIFO (w/ ctx switch) : … [all …]
|
/Zephyr-latest/include/zephyr/sd/ |
D | sdio.h | 108 * @brief Read bytes from SDIO fifo 110 * Reads bytes from SDIO register, treating it as a fifo. Reads will 113 * @param reg: register address of fifo 114 * @param data: filled with data read from fifo 125 * @brief Write bytes to SDIO fifo 127 * Writes bytes to SDIO register, treating it as a fifo. Writes will 130 * @param reg: register address of fifo 131 * @param data: data to write to fifo 142 * @brief Read blocks from SDIO fifo 144 * Reads blocks from SDIO register, treating it as a fifo. Reads will [all …]
|
/Zephyr-latest/tests/bsim/bluetooth/ll/edtt/common/ |
D | edtt_driver_bsim.c | 36 /* In this mode, when the EDTTool closes the FIFO we automatically terminate 43 static int fifo[2] = { -1, -1 }; variable 140 if (write(fifo[TO_EDTT], ptr, size) != size) { in edtt_write() 146 bs_trace_error_line("EDTT IF filled up (FIFO " in edtt_write() 202 fifo[TO_EDTT] = open(fifo_path[TO_EDTT], O_WRONLY); in edptd_create_fifo_if() 203 if (fifo[TO_EDTT] == -1) { in edptd_create_fifo_if() 207 flags = fcntl(fifo[TO_EDTT], F_GETFL); in edptd_create_fifo_if() 209 fcntl(fifo[TO_EDTT], F_SETFL, flags); in edptd_create_fifo_if() 212 fifo[TO_DEVICE] = open(fifo_path[TO_DEVICE], O_RDONLY); in edptd_create_fifo_if() 213 if (fifo[TO_DEVICE] == -1) { in edptd_create_fifo_if() [all …]
|
/Zephyr-latest/dts/bindings/can/ |
D | bosch,m_can-base.yaml | 13 rx-buffer-elements tx-event-fifo-elements tx-buffer-elements> 17 specify how many elements are allocated for each filter type/FIFO/buffer. 22 Rx FIFO 0 0-64 elements / 0-1152 words 23 Rx FIFO 1 0-64 elements / 0-1152 words 25 Tx Event FIFO 0-32 elements / 0-64 words
|
/Zephyr-latest/tests/drivers/uart/uart_emul/ |
D | uart_emul.overlay | 12 rx-fifo-size = <256>; 13 tx-fifo-size = <256>; 20 rx-fifo-size = <256>; 21 tx-fifo-size = <256>;
|
/Zephyr-latest/drivers/i3c/ |
D | Kconfig.stm32 | 26 int "Status FIFO and control FIFO heap" 31 storing status FIFO and control FIFO words which will be used by the DMA.
|
/Zephyr-latest/tests/subsys/logging/log_backend_uart/ |
D | multi.overlay | 21 rx-fifo-size = <256>; 22 tx-fifo-size = <256>; 29 rx-fifo-size = <256>; 30 tx-fifo-size = <256>;
|
/Zephyr-latest/dts/bindings/spi/ |
D | nxp,dspi.yaml | 62 rx-fifo-overwrite: 65 receive FIFO overflow overwrite enable. If ROOE = 0, the incoming 75 tx-fifo-size: 78 tx fifo size 80 rx-fifo-size: 83 rx fifo size
|