i2c: xiic: Fix big-endian register access
authorThomas Gessler <Thomas.Gessler@exp2.physik.uni-giessen.de>
Mon, 13 Oct 2014 16:08:47 +0000 (18:08 +0200)
committerWolfram Sang <wsa@the-dreams.de>
Mon, 17 Nov 2014 18:54:23 +0000 (19:54 +0100)
commit48ef3ca98d92201c36f50ffb5409c38b02e2e953
treee7f02a293688210ee1ac301eb348f0c9ed36ad29
parenta839ce663b3183209fdf7b1fc4796bfe2a4679c3
i2c: xiic: Fix big-endian register access

The driver tried to access device registers with the (little-endian)
iowrite/ioread functions. While this worked on little-endian machines
(e.g. Microblaze with AXI bus), it made the driver unusable on
big-endian machines (e.g. PPC405 with PLB).

During the probe function, the driver tried to write a 32-bit reset mask
into the reset register. This caused an error interrupt on big-endian
systems, because the device detected an invalid (byte-swapped) reset
mask. The result was an Oops.

The patch implements an endianness detection similar to the one used in
other Xilinx drivers like drivers/spi/spi-xilinx.c. It was tested on a
PPC405/PLB system.

Signed-off-by: Thomas Gessler <Thomas.Gessler@exp2.physik.uni-giessen.de>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
drivers/i2c/busses/i2c-xiic.c