summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/macppc/dev/adb.c109
-rw-r--r--sys/arch/macppc/dev/adbvar.h14
2 files changed, 65 insertions, 58 deletions
diff --git a/sys/arch/macppc/dev/adb.c b/sys/arch/macppc/dev/adb.c
index b479e22f856..5cc42ed6415 100644
--- a/sys/arch/macppc/dev/adb.c
+++ b/sys/arch/macppc/dev/adb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: adb.c,v 1.38 2013/07/06 14:28:48 mpi Exp $ */
+/* $OpenBSD: adb.c,v 1.39 2013/08/10 08:13:32 mpi Exp $ */
/* $NetBSD: adb.c,v 1.6 1999/08/16 06:28:09 tsubai Exp $ */
/* $NetBSD: adb_direct.c,v 1.14 2000/06/08 22:10:45 tsubai Exp $ */
@@ -170,17 +170,6 @@ int adb_debug; /* Output debugging messages */
#define ADB_TICKLE_TICKS 4
/*
- * A structure for storing information about each ADB device.
- */
-struct ADBDevEntry {
- void (*ServiceRtPtr)(void);
- void *DataAreaAddr;
- int devType;
- int origAddr;
- int currentAddr;
-};
-
-/*
* Eventually used for two separate queues, the queue between
* the upper and lower halves, and the outgoing packet queue.
*/
@@ -214,9 +203,6 @@ u_char adbOutputBuffer[ADB_MAX_MSG_LENGTH]; /* data output buffer */
int adbSentChars; /* how many characters we have sent */
-struct ADBDevEntry ADBDevTable[16]; /* our ADB device table */
-int ADBNumDevices; /* num. of ADB devices found with adb_reinit */
-
struct adbCommand adbInbound[ADB_QUEUE]; /* incoming queue */
int adbInCount; /* how many packets in in queue */
int adbInHead; /* head of in queue */
@@ -229,6 +215,8 @@ struct timeout adb_cuda_timeout;
struct timeout adb_softintr_timeout;
int adbempty; /* nonzero if no adb devices */
+extern struct cfdriver adb_cd;
+
volatile u_char *Via1Base;
/*
@@ -243,9 +231,9 @@ int send_adb_cuda(u_char *, u_char *, void *, void *, int);
void adb_cuda_tickle(void);
void adb_pass_up(struct adbCommand *);
void adb_op_comprout(caddr_t, caddr_t, int);
-void adb_reinit(void);
-int count_adbs(void);
-int get_ind_adb_info(ADBDataBlock *, int);
+void adb_reinit(struct adb_softc *);
+int count_adbs(struct adb_softc *);
+int get_ind_adb_info(struct adb_softc *, ADBDataBlock *, int);
int get_adb_info(ADBDataBlock *, int);
int adb_op(Ptr, Ptr, Ptr, short);
void adb_hw_setup(void);
@@ -953,7 +941,7 @@ adb_hw_setup(void)
*
*/
void
-adb_reinit(void)
+adb_reinit(struct adb_softc *sc)
{
u_char send_string[ADB_MAX_MSG_LENGTH];
ADBDataBlock data; /* temp. holder for getting device info */
@@ -964,13 +952,12 @@ adb_reinit(void)
int saveptr; /* point to next free relocation address */
int device;
int nonewtimes; /* times thru loop w/o any new devices */
+ int ADBNumDevices = 0;
/* Make sure we are not interrupted while building the table. */
if (adbHardware != ADB_HW_PMU) /* ints must be on for PB? */
s = splhigh();
- ADBNumDevices = 0; /* no devices yet */
-
/* Let intr routines know we are running reinit */
adbStarting = 1;
@@ -979,7 +966,7 @@ adb_reinit(void)
* that is defined at the beginning of this file - no mallocs.
*/
for (i = 0; i < 16; i++)
- ADBDevTable[i].devType = 0;
+ sc->sc_devtable[i].handler_id = 0;
adb_hw_setup(); /* init the VIA bits and hard reset ADB */
@@ -1025,12 +1012,12 @@ adb_reinit(void)
/* found a device */
++ADBNumDevices;
KASSERT(ADBNumDevices < 16);
- ADBDevTable[ADBNumDevices].devType =
+ sc->sc_devtable[ADBNumDevices].handler_id =
(int)send_string[2];
- ADBDevTable[ADBNumDevices].origAddr = i;
- ADBDevTable[ADBNumDevices].currentAddr = i;
- ADBDevTable[ADBNumDevices].DataAreaAddr = NULL;
- ADBDevTable[ADBNumDevices].ServiceRtPtr = NULL;
+ sc->sc_devtable[ADBNumDevices].orig_addr = i;
+ sc->sc_devtable[ADBNumDevices].curr_addr = i;
+ sc->sc_devtable[ADBNumDevices].data = NULL;
+ sc->sc_devtable[ADBNumDevices].handler = NULL;
}
}
@@ -1049,7 +1036,7 @@ adb_reinit(void)
nonewtimes = 0; /* no loops w/o new devices */
while (saveptr > 0 && nonewtimes++ < 11) {
for (i = 1; i <= ADBNumDevices; i++) {
- device = ADBDevTable[i].currentAddr;
+ device = sc->sc_devtable[i].curr_addr;
#ifdef ADB_DEBUG
if (adb_debug & 0x80)
printf_intr("moving device 0x%02x to 0x%02x "
@@ -1096,7 +1083,7 @@ adb_reinit(void)
/* new device found */
/* update data for previously moved device */
- ADBDevTable[i].currentAddr = saveptr;
+ sc->sc_devtable[i].curr_addr = saveptr;
#ifdef ADB_DEBUG
if (adb_debug & 0x80)
printf_intr("old device at index %i\n",i);
@@ -1110,14 +1097,14 @@ adb_reinit(void)
++ADBNumDevices;
KASSERT(ADBNumDevices < 16);
}
- ADBDevTable[ADBNumDevices].devType =
+ sc->sc_devtable[ADBNumDevices].handler_id =
(int)send_string[2];
- ADBDevTable[ADBNumDevices].origAddr = device;
- ADBDevTable[ADBNumDevices].currentAddr = device;
+ sc->sc_devtable[ADBNumDevices].orig_addr = device;
+ sc->sc_devtable[ADBNumDevices].curr_addr = device;
/* These will be set correctly in adbsys.c */
/* Until then, unsol. data will be ignored. */
- ADBDevTable[ADBNumDevices].DataAreaAddr = NULL;
- ADBDevTable[ADBNumDevices].ServiceRtPtr = NULL;
+ sc->sc_devtable[ADBNumDevices].data = NULL;
+ sc->sc_devtable[ADBNumDevices].handler = NULL;
/* find next unused address */
for (x = saveptr; x > 0; x--) {
if (-1 == get_adb_info(&data, x)) {
@@ -1152,7 +1139,7 @@ adb_reinit(void)
#ifdef ADB_DEBUG
if (adb_debug) {
for (i = 1; i <= ADBNumDevices; i++) {
- x = get_ind_adb_info(&data, i);
+ x = get_ind_adb_info(sc, &data, i);
if (x != -1)
printf_intr("index 0x%x, addr 0x%x, type 0x%x\n",
i, x, data.devType);
@@ -1273,7 +1260,7 @@ adb_op_comprout(caddr_t buffer, caddr_t compdata, int cmd)
}
int
-count_adbs(void)
+count_adbs(struct adb_softc *sc)
{
int i;
int found;
@@ -1281,48 +1268,52 @@ count_adbs(void)
found = 0;
for (i = 1; i < 16; i++)
- if (0 != ADBDevTable[i].devType)
+ if (0 != sc->sc_devtable[i].handler_id)
found++;
return found;
}
int
-get_ind_adb_info(ADBDataBlock * info, int index)
+get_ind_adb_info(struct adb_softc *sc, ADBDataBlock * info, int index)
{
if ((index < 1) || (index > 15)) /* check range 1-15 */
return (-1);
#ifdef ADB_DEBUG
if (adb_debug & 0x80)
- printf_intr("index 0x%x devType is: 0x%x\n", index,
- ADBDevTable[index].devType);
+ printf_intr("index 0x%x handler id 0x%x\n", index,
+ sc->sc_devtable[index].handler_id);
#endif
- if (0 == ADBDevTable[index].devType) /* make sure it's a valid entry */
+ if (0 == sc->sc_devtable[index].handler_id) /* make sure it's a valid entry */
return (-1);
- info->devType = ADBDevTable[index].devType;
- info->origADBAddr = ADBDevTable[index].origAddr;
- info->dbServiceRtPtr = (Ptr)ADBDevTable[index].ServiceRtPtr;
- info->dbDataAreaAddr = (Ptr)ADBDevTable[index].DataAreaAddr;
+ info->devType = sc->sc_devtable[index].handler_id;
+ info->origADBAddr = sc->sc_devtable[index].orig_addr;
+ info->dbServiceRtPtr = (Ptr)sc->sc_devtable[index].handler;
+ info->dbDataAreaAddr = (Ptr)sc->sc_devtable[index].data;
- return (ADBDevTable[index].currentAddr);
+ return (sc->sc_devtable[index].curr_addr);
}
int
get_adb_info(ADBDataBlock * info, int adbAddr)
{
+ struct adb_softc *sc = adb_cd.cd_devs[0];
int i;
+ if (sc == NULL)
+ return (-1);
+
if ((adbAddr < 1) || (adbAddr > 15)) /* check range 1-15 */
return (-1);
for (i = 1; i < 15; i++)
- if (ADBDevTable[i].currentAddr == adbAddr) {
- info->devType = ADBDevTable[i].devType;
- info->origADBAddr = ADBDevTable[i].origAddr;
- info->dbServiceRtPtr = (Ptr)ADBDevTable[i].ServiceRtPtr;
- info->dbDataAreaAddr = ADBDevTable[i].DataAreaAddr;
+ if (sc->sc_devtable[i].curr_addr == adbAddr) {
+ info->devType = sc->sc_devtable[i].handler_id;
+ info->origADBAddr = sc->sc_devtable[i].orig_addr;
+ info->dbServiceRtPtr = (Ptr)sc->sc_devtable[i].handler;
+ info->dbDataAreaAddr = sc->sc_devtable[i].data;
return 0; /* found */
}
@@ -1332,16 +1323,20 @@ get_adb_info(ADBDataBlock * info, int adbAddr)
int
set_adb_info(ADBSetInfoBlock * info, int adbAddr)
{
+ struct adb_softc *sc = adb_cd.cd_devs[0];
int i;
+ if (sc == NULL)
+ return (-1);
+
if ((adbAddr < 1) || (adbAddr > 15)) /* check range 1-15 */
return (-1);
for (i = 1; i < 15; i++)
- if (ADBDevTable[i].currentAddr == adbAddr) {
- ADBDevTable[i].ServiceRtPtr =
+ if (sc->sc_devtable[i].curr_addr == adbAddr) {
+ sc->sc_devtable[i].handler =
(void *)(info->siServiceRtPtr);
- ADBDevTable[i].DataAreaAddr = info->siDataAreaAddr;
+ sc->sc_devtable[i].data = info->siDataAreaAddr;
return 0; /* found */
}
@@ -1624,8 +1619,8 @@ adbattach(struct device *parent, struct device *self, void *aux)
adb_polling = 1;
if (!adbempty) {
- adb_reinit();
- totaladbs = count_adbs();
+ adb_reinit(sc);
+ totaladbs = count_adbs(sc);
printf(": irq %d, %s, %d target%s", ca->ca_intr[0], ca->ca_name,
totaladbs, (totaladbs == 1) ? "" : "s");
}
@@ -1674,7 +1669,7 @@ adbattach(struct device *parent, struct device *self, void *aux)
/* for each ADB device */
for (adbindex = 1; adbindex <= totaladbs; adbindex++) {
/* Get the ADB information */
- adbaddr = get_ind_adb_info(&adbdata, adbindex);
+ adbaddr = get_ind_adb_info(sc, &adbdata, adbindex);
aa_args.name = adb_device_name;
aa_args.origaddr = adbdata.origADBAddr;
diff --git a/sys/arch/macppc/dev/adbvar.h b/sys/arch/macppc/dev/adbvar.h
index dbf1270f06e..8e55817d019 100644
--- a/sys/arch/macppc/dev/adbvar.h
+++ b/sys/arch/macppc/dev/adbvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: adbvar.h,v 1.9 2013/03/09 11:33:25 mpi Exp $ */
+/* $OpenBSD: adbvar.h,v 1.10 2013/08/10 08:13:32 mpi Exp $ */
/* $NetBSD: adbvar.h,v 1.3 2000/06/08 22:10:46 tsubai Exp $ */
/*-
@@ -26,9 +26,21 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
+
+struct adb_device {
+ int handler_id;
+ int orig_addr;
+ int curr_addr;
+
+ void (*handler)(void);
+ void *data;
+};
+
struct adb_softc {
struct device sc_dev;
char *sc_regbase;
+
+ struct adb_device sc_devtable[16];
};
extern int adbHardware;