11.3Sthorpej/*	$NetBSD: imx51_i2c.c,v 1.3 2022/07/22 23:43:23 thorpej Exp $	*/
21.1Shkenken
31.1Shkenken/*
41.2Shkenken * Copyright (c) 2012, 2015 Genetec Corporation.  All rights reserved.
51.1Shkenken * Written by Hashimoto Kenichi for Genetec Corporation.
61.1Shkenken *
71.1Shkenken * Redistribution and use in source and binary forms, with or without
81.1Shkenken * modification, are permitted provided that the following conditions
91.1Shkenken * are met:
101.1Shkenken * 1. Redistributions of source code must retain the above copyright
111.1Shkenken *    notice, this list of conditions and the following disclaimer.
121.1Shkenken * 2. Redistributions in binary form must reproduce the above copyright
131.1Shkenken *    notice, this list of conditions and the following disclaimer in the
141.1Shkenken *    documentation and/or other materials provided with the distribution.
151.1Shkenken *
161.1Shkenken * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
171.1Shkenken * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
181.1Shkenken * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
191.1Shkenken * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
201.1Shkenken * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
211.1Shkenken * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
221.1Shkenken * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
231.1Shkenken * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
241.1Shkenken * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
251.1Shkenken * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
261.1Shkenken * SUCH DAMAGE.
271.1Shkenken */
281.1Shkenken
291.1Shkenken#include <sys/cdefs.h>
301.3Sthorpej__KERNEL_RCSID(0, "$NetBSD: imx51_i2c.c,v 1.3 2022/07/22 23:43:23 thorpej Exp $");
311.2Shkenken
321.2Shkenken#include "opt_imx.h"
331.1Shkenken
341.1Shkenken#include <sys/param.h>
351.1Shkenken#include <sys/bus.h>
361.1Shkenken#include <sys/device.h>
371.1Shkenken
381.1Shkenken#include <arm/imx/imx51reg.h>
391.1Shkenken#include <arm/imx/imx51var.h>
401.1Shkenken#include <arm/imx/imx51_ccmvar.h>
411.2Shkenken#include <arm/imx/imxi2cvar.h>
421.1Shkenken
431.1Shkenkenint
441.1Shkenkenimxi2c_match(device_t parent, cfdata_t cf, void *aux)
451.1Shkenken{
461.2Shkenken	struct axi_attach_args *aa = aux;
471.2Shkenken
481.2Shkenken	switch (aa->aa_addr) {
491.2Shkenken	case I2C1_BASE:
501.2Shkenken	case I2C2_BASE:
511.2Shkenken#ifdef IMX50
521.2Shkenken	case I2C3_BASE:
531.2Shkenken#endif
541.1Shkenken		return 1;
551.2Shkenken	}
561.1Shkenken
571.1Shkenken	return 0;
581.1Shkenken}
591.1Shkenken
601.1Shkenkenvoid
611.1Shkenkenimxi2c_attach(device_t parent, device_t self, void *aux)
621.1Shkenken{
631.1Shkenken	struct axi_attach_args * aa = aux;
641.1Shkenken
651.2Shkenken	if (aa->aa_size <= 0)
661.2Shkenken		aa->aa_size = I2C_SIZE;
671.2Shkenken
681.3Sthorpej	imxi2c_attach_common(self,
691.3Sthorpej	    aa->aa_iot, aa->aa_addr, aa->aa_size,
701.3Sthorpej	    imx51_get_clock(IMX51CLK_PERCLK_ROOT), 400000);
711.1Shkenken}
72