Simon,
Now I am seeing driver/serial/serial_tegra.c U_BOOT_DRIVER(serial_ns16550) = { .name = "serial_tegra20", .id = UCLASS_SERIAL, .of_match = tegra_serial_ids, .ofdata_to_platdata = tegra_serial_ofdata_to_platdata, .platdata_auto_alloc_size = sizeof(struct ns16550_platdata), .priv_auto_alloc_size = sizeof(struct NS16550), .probe = ns16550_serial_probe, .ops = &ns16550_serial_ops, You require sizeof(struct NS16550) (= about 30~ 40 bytes) for .priv_auto_alloc_size. Seems strange. It looks like the private date is used as the base address of the hardware Here, struct NS16550 *const com_port = dev_get_priv(dev); If the hardware register has 0x10000 width, do we need to allocation 0x10000 memory for .priv data? I think 4 byte (or 8 byte on 64bit architectures) is enough to store the base address. It looks like the memory is allocated for .priv in device_probe() function, but I could not find where .priv is set for pointing to the base address. Perhaps I am not understanding well yet, but I'm still not convinced how it is working. Best Regards Masahiro Yamada _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot