M7350/kernel/arch/arm/mach-imx/ssi-fiq.S

148 lines
2.9 KiB
ArmAsm
Raw Normal View History

2024-09-09 08:52:07 +00:00
/*
* Copyright (C) 2009 Sascha Hauer <s.hauer@pengutronix.de>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#include <linux/linkage.h>
#include <asm/assembler.h>
/*
* r8 = bit 0-15: tx offset, bit 16-31: tx buffer size
* r9 = bit 0-15: rx offset, bit 16-31: rx buffer size
*/
#define SSI_STX0 0x00
#define SSI_SRX0 0x08
#define SSI_SISR 0x14
#define SSI_SIER 0x18
#define SSI_SACNT 0x38
#define SSI_SACNT_AC97EN (1 << 0)
#define SSI_SIER_TFE0_EN (1 << 0)
#define SSI_SISR_TFE0 (1 << 0)
#define SSI_SISR_RFF0 (1 << 2)
#define SSI_SIER_RFF0_EN (1 << 2)
.text
.global imx_ssi_fiq_start
.global imx_ssi_fiq_end
.global imx_ssi_fiq_base
.global imx_ssi_fiq_rx_buffer
.global imx_ssi_fiq_tx_buffer
2024-09-09 08:57:42 +00:00
/*
* imx_ssi_fiq_start is _intentionally_ not marked as a function symbol
* using ENDPROC(). imx_ssi_fiq_start and imx_ssi_fiq_end are used to
* mark the function body so that it can be copied to the FIQ vector in
* the vectors page. imx_ssi_fiq_start should only be called as the result
* of an FIQ: calling it directly will not work.
*/
2024-09-09 08:52:07 +00:00
imx_ssi_fiq_start:
2024-09-09 08:57:42 +00:00
ldr r12, .L_imx_ssi_fiq_base
2024-09-09 08:52:07 +00:00
/* TX */
2024-09-09 08:57:42 +00:00
ldr r13, .L_imx_ssi_fiq_tx_buffer
2024-09-09 08:52:07 +00:00
/* shall we send? */
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SIER]
tst r11, #SSI_SIER_TFE0_EN
2024-09-09 08:52:07 +00:00
beq 1f
/* TX FIFO empty? */
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SISR]
tst r11, #SSI_SISR_TFE0
2024-09-09 08:52:07 +00:00
beq 1f
mov r10, #0x10000
sub r10, #1
and r10, r10, r8 /* r10: current buffer offset */
2024-09-09 08:57:42 +00:00
add r13, r13, r10
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldrh r11, [r13]
strh r11, [r12, #SSI_STX0]
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldrh r11, [r13, #2]
strh r11, [r12, #SSI_STX0]
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldrh r11, [r13, #4]
strh r11, [r12, #SSI_STX0]
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldrh r11, [r13, #6]
strh r11, [r12, #SSI_STX0]
2024-09-09 08:52:07 +00:00
add r10, #8
2024-09-09 08:57:42 +00:00
lsr r11, r8, #16 /* r11: buffer size */
cmp r10, r11
lslgt r8, r11, #16
2024-09-09 08:52:07 +00:00
addle r8, #8
1:
/* RX */
/* shall we receive? */
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SIER]
tst r11, #SSI_SIER_RFF0_EN
2024-09-09 08:52:07 +00:00
beq 1f
/* RX FIFO full? */
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SISR]
tst r11, #SSI_SISR_RFF0
2024-09-09 08:52:07 +00:00
beq 1f
2024-09-09 08:57:42 +00:00
ldr r13, .L_imx_ssi_fiq_rx_buffer
2024-09-09 08:52:07 +00:00
mov r10, #0x10000
sub r10, #1
and r10, r10, r9 /* r10: current buffer offset */
2024-09-09 08:57:42 +00:00
add r13, r13, r10
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SACNT]
tst r11, #SSI_SACNT_AC97EN
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SRX0]
strh r11, [r13]
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SRX0]
strh r11, [r13, #2]
2024-09-09 08:52:07 +00:00
/* dummy read to skip slot 12 */
2024-09-09 08:57:42 +00:00
ldrne r11, [r12, #SSI_SRX0]
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SRX0]
strh r11, [r13, #4]
2024-09-09 08:52:07 +00:00
2024-09-09 08:57:42 +00:00
ldr r11, [r12, #SSI_SRX0]
strh r11, [r13, #6]
2024-09-09 08:52:07 +00:00
/* dummy read to skip slot 12 */
2024-09-09 08:57:42 +00:00
ldrne r11, [r12, #SSI_SRX0]
2024-09-09 08:52:07 +00:00
add r10, #8
2024-09-09 08:57:42 +00:00
lsr r11, r9, #16 /* r11: buffer size */
cmp r10, r11
lslgt r9, r11, #16
2024-09-09 08:52:07 +00:00
addle r9, #8
1:
@ return from FIQ
subs pc, lr, #4
.align
2024-09-09 08:57:42 +00:00
.L_imx_ssi_fiq_base:
2024-09-09 08:52:07 +00:00
imx_ssi_fiq_base:
.word 0x0
2024-09-09 08:57:42 +00:00
.L_imx_ssi_fiq_rx_buffer:
2024-09-09 08:52:07 +00:00
imx_ssi_fiq_rx_buffer:
.word 0x0
2024-09-09 08:57:42 +00:00
.L_imx_ssi_fiq_tx_buffer:
2024-09-09 08:52:07 +00:00
imx_ssi_fiq_tx_buffer:
.word 0x0
2024-09-09 08:57:42 +00:00
.L_imx_ssi_fiq_end:
2024-09-09 08:52:07 +00:00
imx_ssi_fiq_end: