/* SPDX-License-Identifier: GPL-2.0 */
#ifndef OLPC_DCON_H_
#define OLPC_DCON_H_
#include <linux/notifier.h>
#include <linux/workqueue.h>
/* DCON registers */
#define DCON_REG_ID 0
#define DCON_REG_MODE 1
#define MODE_PASSTHRU BIT(0)
#define MODE_SLEEP BIT(1)
#define MODE_SLEEP_AUTO BIT(2)
#define MODE_BL_ENABLE BIT(3)
#define MODE_BLANK BIT(4)
#define MODE_CSWIZZLE BIT(5)
#define MODE_COL_AA BIT(6)
#define MODE_MONO_LUMA BIT(7)
#define MODE_SCAN_INT BIT(8)
#define MODE_CLOCKDIV BIT(9)
#define MODE_DEBUG BIT(14)
#define MODE_SELFTEST BIT(15)
#define DCON_REG_HRES 0x2
#define DCON_REG_HTOTAL 0x3
#define DCON_REG_HSYNC_WIDTH 0x4
#define DCON_REG_VRES 0x5
#define DCON_REG_VTOTAL 0x6
#define DCON_REG_VSYNC_WIDTH 0x7
#define DCON_REG_TIMEOUT 0x8
#define DCON_REG_SCAN_INT 0x9
#define DCON_REG_BRIGHT 0xa
#define DCON_REG_MEM_OPT_A 0x41
#define DCON_REG_MEM_OPT_B 0x42
/* Load Delay Locked Loop (DLL) settings for clock delay */
#define MEM_DLL_CLOCK_DELAY BIT(0)
/* Memory controller power down function */
#define MEM_POWER_DOWN BIT(8)
/* Memory controller software reset */
#define MEM_SOFT_RESET BIT(0)
/* Status values */
#define DCONSTAT_SCANINT 0
#define DCONSTAT_SCANINT_DCON 1
#define DCONSTAT_DISPLAYLOAD 2
#define DCONSTAT_MISSED 3
/* Source values */
#define DCON_SOURCE_DCON 0
#define DCON_SOURCE_CPU 1
/* Interrupt */
#define DCON_IRQ 6
struct dcon_priv {
struct i2c_client *client;
struct fb_info *fbinfo;
struct backlight_device *bl_dev;
wait_queue_head_t waitq;
struct work_struct switch_source;
struct notifier_block reboot_nb;
/* Shadow register for the DCON_REG_MODE register */
u8 disp_mode;
/* The current backlight value - this saves us some smbus traffic */
u8 bl_val;
/* Current source, initialized at probe time */
int curr_src;
/* Desired source */
int pending_src;
/* Variables used during switches */
bool switched;
ktime_t irq_time;
ktime_t load_time;
/* Current output type; true == mono, false == color */
bool mono;
bool asleep;
/* This get set while controlling fb blank state from the driver */
bool ignore_fb_events;
};
struct dcon_platform_data {
int (*init)(struct dcon_priv *dcon);
void (*bus_stabilize_wiggle)(void);
void (*set_dconload)(int load);
int (*read_status)(u8 *status);
};
struct dcon_gpio {
const char *name;
unsigned long flags;
};
#include <linux/interrupt.h>
irqreturn_t dcon_interrupt(int irq, void *id);
extern struct dcon_platform_data dcon_pdata_xo_1;
extern struct dcon_platform_data dcon_pdata_xo_1_5;
#endif