diff options
author | Jason Wright <jason@cvs.openbsd.org> | 2003-08-22 19:11:23 +0000 |
---|---|---|
committer | Jason Wright <jason@cvs.openbsd.org> | 2003-08-22 19:11:23 +0000 |
commit | 27e9ea4d917c2b59c5e5e5d4a93a9db53211632c (patch) | |
tree | 6488a10105bf1f64c667947dd827bc58fa12f2e5 /sys/dev/pci/safe.c | |
parent | 6c37c880e67d9d8faa8aaa2e5b2ffb1d9f63af54 (diff) |
need to flip the operands wordwise for big endian machines. modexp works
on ppc now.
Diffstat (limited to 'sys/dev/pci/safe.c')
-rw-r--r-- | sys/dev/pci/safe.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/sys/dev/pci/safe.c b/sys/dev/pci/safe.c index ac10cc3f1da..e21e5da406a 100644 --- a/sys/dev/pci/safe.c +++ b/sys/dev/pci/safe.c @@ -1,4 +1,4 @@ -/* $OpenBSD: safe.c,v 1.9 2003/08/20 22:23:13 jason Exp $ */ +/* $OpenBSD: safe.c,v 1.10 2003/08/22 19:11:22 jason Exp $ */ /*- * Copyright (c) 2003 Sam Leffler, Errno Consulting @@ -2026,8 +2026,8 @@ safe_kpoll(void *vsc) bzero(buf, sizeof(buf)); bzero(res->crp_p, (res->crp_nbits + 7) / 8); for (i = 0; i < sc->sc_pk_reslen >> 2; i++) - buf[i] = READ_REG(sc, SAFE_PK_RAM_START + sc->sc_pk_resoff + - (i << 2)); + buf[i] = letoh32(READ_REG(sc, SAFE_PK_RAM_START + + sc->sc_pk_resoff + (i << 2))); bcopy(buf, res->crp_p, (res->crp_nbits + 7) / 8); res->crp_nbits = sc->sc_pk_reslen * 8; res->crp_nbits = safe_ksigbits(res); @@ -2054,7 +2054,8 @@ safe_kload_reg(struct safe_softc *sc, u_int32_t off, u_int32_t len, bcopy(n->crp_p, buf, (n->crp_nbits + 7) / 8); for (i = 0; i < len >> 2; i++) - WRITE_REG(sc, SAFE_PK_RAM_START + off + (i << 2), buf[i]); + WRITE_REG(sc, SAFE_PK_RAM_START + off + (i << 2), + htole32(buf[i])); } #ifdef SAFE_DEBUG |