Lines Matching full:mhu
112 struct arm_mhu *mhu; in mhu_probe() local
116 if (!of_device_is_compatible(dev->of_node, "arm,mhu")) in mhu_probe()
120 mhu = devm_kzalloc(dev, sizeof(*mhu), GFP_KERNEL); in mhu_probe()
121 if (!mhu) in mhu_probe()
124 mhu->base = devm_ioremap_resource(dev, &adev->res); in mhu_probe()
125 if (IS_ERR(mhu->base)) { in mhu_probe()
127 return PTR_ERR(mhu->base); in mhu_probe()
131 mhu->chan[i].con_priv = &mhu->mlink[i]; in mhu_probe()
132 mhu->mlink[i].irq = adev->irq[i]; in mhu_probe()
133 mhu->mlink[i].rx_reg = mhu->base + mhu_reg[i]; in mhu_probe()
134 mhu->mlink[i].tx_reg = mhu->mlink[i].rx_reg + TX_REG_OFFSET; in mhu_probe()
137 mhu->mbox.dev = dev; in mhu_probe()
138 mhu->mbox.chans = &mhu->chan[0]; in mhu_probe()
139 mhu->mbox.num_chans = MHU_CHANS; in mhu_probe()
140 mhu->mbox.ops = &mhu_ops; in mhu_probe()
141 mhu->mbox.txdone_irq = false; in mhu_probe()
142 mhu->mbox.txdone_poll = true; in mhu_probe()
143 mhu->mbox.txpoll_period = 1; in mhu_probe()
145 amba_set_drvdata(adev, mhu); in mhu_probe()
147 err = devm_mbox_controller_register(dev, &mhu->mbox); in mhu_probe()
153 dev_info(dev, "ARM MHU Mailbox registered\n"); in mhu_probe()
168 .name = "mhu",
176 MODULE_DESCRIPTION("ARM MHU Driver");