mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-11 13:04:03 +08:00
2b27bdcc20
Based on 1 normalized pattern(s): 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 this program is distributed in the hope that it will be useful but without any warranty without even the implied warranty of merchantability or fitness for a particular purpose see the gnu general public license for more details you should have received a copy of the gnu general public license along with this program if not write to the free software foundation inc 51 franklin st fifth floor boston ma 02110 1301 usa extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 246 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Alexios Zavras <alexios.zavras@intel.com> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190530000436.674189849@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
165 lines
4.7 KiB
C
165 lines
4.7 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/* OMAP SSI internal interface.
|
|
*
|
|
* Copyright (C) 2010 Nokia Corporation. All rights reserved.
|
|
* Copyright (C) 2013 Sebastian Reichel
|
|
*
|
|
* Contact: Carlos Chinea <carlos.chinea@nokia.com>
|
|
*/
|
|
|
|
#ifndef __LINUX_HSI_OMAP_SSI_H__
|
|
#define __LINUX_HSI_OMAP_SSI_H__
|
|
|
|
#include <linux/device.h>
|
|
#include <linux/module.h>
|
|
#include <linux/platform_device.h>
|
|
#include <linux/hsi/hsi.h>
|
|
#include <linux/gpio/consumer.h>
|
|
#include <linux/interrupt.h>
|
|
#include <linux/io.h>
|
|
|
|
#define SSI_MAX_CHANNELS 8
|
|
#define SSI_MAX_GDD_LCH 8
|
|
#define SSI_BYTES_TO_FRAMES(x) ((((x) - 1) >> 2) + 1)
|
|
|
|
#define SSI_WAKE_EN 0
|
|
|
|
/**
|
|
* struct omap_ssm_ctx - OMAP synchronous serial module (TX/RX) context
|
|
* @mode: Bit transmission mode
|
|
* @channels: Number of channels
|
|
* @framesize: Frame size in bits
|
|
* @timeout: RX frame timeout
|
|
* @divisor: TX divider
|
|
* @arb_mode: Arbitration mode for TX frame (Round robin, priority)
|
|
*/
|
|
struct omap_ssm_ctx {
|
|
u32 mode;
|
|
u32 channels;
|
|
u32 frame_size;
|
|
union {
|
|
u32 timeout; /* Rx Only */
|
|
struct {
|
|
u32 arb_mode;
|
|
u32 divisor;
|
|
}; /* Tx only */
|
|
};
|
|
};
|
|
|
|
/**
|
|
* struct omap_ssi_port - OMAP SSI port data
|
|
* @dev: device associated to the port (HSI port)
|
|
* @pdev: platform device associated to the port
|
|
* @sst_dma: SSI transmitter physical base address
|
|
* @ssr_dma: SSI receiver physical base address
|
|
* @sst_base: SSI transmitter base address
|
|
* @ssr_base: SSI receiver base address
|
|
* @wk_lock: spin lock to serialize access to the wake lines
|
|
* @lock: Spin lock to serialize access to the SSI port
|
|
* @channels: Current number of channels configured (1,2,4 or 8)
|
|
* @txqueue: TX message queues
|
|
* @rxqueue: RX message queues
|
|
* @brkqueue: Queue of incoming HWBREAK requests (FRAME mode)
|
|
* @errqueue: Queue for failed messages
|
|
* @errqueue_work: Delayed Work for failed messages
|
|
* @irq: IRQ number
|
|
* @wake_irq: IRQ number for incoming wake line (-1 if none)
|
|
* @wake_gpio: GPIO number for incoming wake line (-1 if none)
|
|
* @flags: flags to keep track of states
|
|
* @wk_refcount: Reference count for output wake line
|
|
* @work: worker for starting TX
|
|
* @sys_mpu_enable: Context for the interrupt enable register for irq 0
|
|
* @sst: Context for the synchronous serial transmitter
|
|
* @ssr: Context for the synchronous serial receiver
|
|
*/
|
|
struct omap_ssi_port {
|
|
struct device *dev;
|
|
struct device *pdev;
|
|
dma_addr_t sst_dma;
|
|
dma_addr_t ssr_dma;
|
|
void __iomem *sst_base;
|
|
void __iomem *ssr_base;
|
|
spinlock_t wk_lock;
|
|
spinlock_t lock;
|
|
unsigned int channels;
|
|
struct list_head txqueue[SSI_MAX_CHANNELS];
|
|
struct list_head rxqueue[SSI_MAX_CHANNELS];
|
|
struct list_head brkqueue;
|
|
struct list_head errqueue;
|
|
struct delayed_work errqueue_work;
|
|
unsigned int irq;
|
|
int wake_irq;
|
|
struct gpio_desc *wake_gpio;
|
|
bool wktest:1; /* FIXME: HACK to be removed */
|
|
unsigned long flags;
|
|
unsigned int wk_refcount;
|
|
struct work_struct work;
|
|
/* OMAP SSI port context */
|
|
u32 sys_mpu_enable; /* We use only one irq */
|
|
struct omap_ssm_ctx sst;
|
|
struct omap_ssm_ctx ssr;
|
|
u32 loss_count;
|
|
u32 port_id;
|
|
#ifdef CONFIG_DEBUG_FS
|
|
struct dentry *dir;
|
|
#endif
|
|
};
|
|
|
|
/**
|
|
* struct gdd_trn - GDD transaction data
|
|
* @msg: Pointer to the HSI message being served
|
|
* @sg: Pointer to the current sg entry being served
|
|
*/
|
|
struct gdd_trn {
|
|
struct hsi_msg *msg;
|
|
struct scatterlist *sg;
|
|
};
|
|
|
|
/**
|
|
* struct omap_ssi_controller - OMAP SSI controller data
|
|
* @dev: device associated to the controller (HSI controller)
|
|
* @sys: SSI I/O base address
|
|
* @gdd: GDD I/O base address
|
|
* @fck: SSI functional clock
|
|
* @gdd_irq: IRQ line for GDD
|
|
* @gdd_tasklet: bottom half for DMA transfers
|
|
* @gdd_trn: Array of GDD transaction data for ongoing GDD transfers
|
|
* @lock: lock to serialize access to GDD
|
|
* @fck_nb: DVFS notfifier block
|
|
* @fck_rate: clock rate
|
|
* @loss_count: To follow if we need to restore context or not
|
|
* @max_speed: Maximum TX speed (Kb/s) set by the clients.
|
|
* @gdd_gcr: SSI GDD saved context
|
|
* @get_loss: Pointer to omap_pm_get_dev_context_loss_count, if any
|
|
* @port: Array of pointers of the ports of the controller
|
|
* @dir: Debugfs SSI root directory
|
|
*/
|
|
struct omap_ssi_controller {
|
|
struct device *dev;
|
|
void __iomem *sys;
|
|
void __iomem *gdd;
|
|
struct clk *fck;
|
|
unsigned int gdd_irq;
|
|
struct tasklet_struct gdd_tasklet;
|
|
struct gdd_trn gdd_trn[SSI_MAX_GDD_LCH];
|
|
spinlock_t lock;
|
|
struct notifier_block fck_nb;
|
|
unsigned long fck_rate;
|
|
u32 loss_count;
|
|
u32 max_speed;
|
|
/* OMAP SSI Controller context */
|
|
u32 gdd_gcr;
|
|
int (*get_loss)(struct device *dev);
|
|
struct omap_ssi_port **port;
|
|
#ifdef CONFIG_DEBUG_FS
|
|
struct dentry *dir;
|
|
#endif
|
|
};
|
|
|
|
void omap_ssi_port_update_fclk(struct hsi_controller *ssi,
|
|
struct omap_ssi_port *omap_port);
|
|
|
|
extern struct platform_driver ssi_port_pdriver;
|
|
|
|
#endif /* __LINUX_HSI_OMAP_SSI_H__ */
|