#ifndef _L1_ASYNC_H #define _L1_ASYNC_H #include #include #if 0 NOTE: Re-enabling interrupts causes an IRQ while processing the same IRQ. Use local_firq_save and local_irq_restore instead! /* When altering data structures used by L1 Sync part, we need to * make sure to temporarily disable IRQ/FIQ to keep data consistent */ static inline void l1a_lock_sync(void) { arm_disable_interrupts(); } static inline void l1a_unlock_sync(void) { arm_enable_interrupts(); } #endif /* safely enable a message into the L1S TX queue */ void l1a_txq_msgb_enq(struct llist_head *queue, struct msgb *msg); void l1a_meas_msgb_set(struct msgb *msg); /* safely count messages in the L1S TX queue */ int l1a_txq_msgb_count(struct llist_head *queue); /* flush all pending msgb */ void l1a_txq_msgb_flush(struct llist_head *queue); /* Enable a repeating multiframe task */ void l1a_mftask_enable(enum mframe_task task); /* Disable a repeating multiframe task */ void l1a_mftask_disable(enum mframe_task task); /* Set the mask for repeating multiframe tasks */ void l1a_mftask_set(uint32_t tasks); /* Set TCH mode */ uint8_t l1a_tch_mode_set(uint8_t mode); /* Set Audio routing mode */ uint8_t l1a_audio_mode_set(uint8_t mode); /* Set TCH flags */ uint8_t l1a_tch_flags_set(uint8_t flags); /* Execute pending L1A completions */ void l1a_compl_execute(void); /* Initialize asynchronous part of Layer1 */ void l1a_init(void); #endif