hc
2024-03-22 f63cd4c03ea42695d5f9b0e1798edd196923aae6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/*
 * hecubafb.h - definitions for the hecuba framebuffer driver
 *
 * Copyright (C) 2008 by Jaya Kumar
 *
 * This file is subject to the terms and conditions of the GNU General Public
 * License. See the file COPYING in the main directory of this archive for
 * more details.
 *
 */
 
#ifndef _LINUX_HECUBAFB_H_
#define _LINUX_HECUBAFB_H_
 
/* Apollo controller specific defines */
#define APOLLO_START_NEW_IMG    0xA0
#define APOLLO_STOP_IMG_DATA    0xA1
#define APOLLO_DISPLAY_IMG    0xA2
#define APOLLO_ERASE_DISPLAY    0xA3
#define APOLLO_INIT_DISPLAY    0xA4
 
/* Hecuba interface specific defines */
#define HCB_WUP_BIT    0x01
#define HCB_DS_BIT     0x02
#define HCB_RW_BIT     0x04
#define HCB_CD_BIT     0x08
#define HCB_ACK_BIT     0x80
 
/* struct used by hecuba. board specific stuff comes from *board */
struct hecubafb_par {
   struct fb_info *info;
   struct hecuba_board *board;
   void (*send_command)(struct hecubafb_par *, unsigned char);
   void (*send_data)(struct hecubafb_par *, unsigned char);
};
 
/* board specific routines
board drivers can implement wait_for_ack with interrupts if desired. if
wait_for_ack is called with clear=0, then go to sleep and return when ack
goes hi or if wait_for_ack with clear=1, then return when ack goes lo */
struct hecuba_board {
   struct module *owner;
   void (*remove)(struct hecubafb_par *);
   void (*set_ctl)(struct hecubafb_par *, unsigned char, unsigned char);
   void (*set_data)(struct hecubafb_par *, unsigned char);
   void (*wait_for_ack)(struct hecubafb_par *, int);
   int (*init)(struct hecubafb_par *);
};
 
 
#endif