cregit-Linux how code gets into the kernel

Release 4.11 sound/soc/codecs/l3.c

Directory: sound/soc/codecs
/*
 * L3 code
 *
 *  Copyright (C) 2008, Christian Pellegrin <chripell@evolware.org>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 *
 * based on:
 *
 * L3 bus algorithm module.
 *
 *  Copyright (C) 2001 Russell King, All Rights Reserved.
 *
 *
 */

#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/delay.h>
#include <linux/device.h>
#include <linux/gpio.h>

#include <sound/l3.h>

/*
 * Send one byte of data to the chip.  Data is latched into the chip on
 * the rising edge of the clock.
 */

static void sendbyte(struct l3_pins *adap, unsigned int byte) { int i; for (i = 0; i < 8; i++) { adap->setclk(adap, 0); udelay(adap->data_hold); adap->setdat(adap, byte & 1); udelay(adap->data_setup); adap->setclk(adap, 1); udelay(adap->clock_high); byte >>= 1; } }

Contributors

PersonTokensPropCommitsCommitProp
Christian Pellegrin8193.10%150.00%
Sylwester Nawrocki66.90%150.00%
Total87100.00%2100.00%

/* * Send a set of bytes to the chip. We need to pulse the MODE line * between each byte, but never at the start nor at the end of the * transfer. */
static void sendbytes(struct l3_pins *adap, const u8 *buf, int len) { int i; for (i = 0; i < len; i++) { if (i) { udelay(adap->mode_hold); adap->setmode(adap, 0); udelay(adap->mode); } adap->setmode(adap, 1); udelay(adap->mode_setup); sendbyte(adap, buf[i]); } }

Contributors

PersonTokensPropCommitsCommitProp
Christian Pellegrin8895.65%150.00%
Sylwester Nawrocki44.35%150.00%
Total92100.00%2100.00%


int l3_write(struct l3_pins *adap, u8 addr, u8 *data, int len) { adap->setclk(adap, 1); adap->setdat(adap, 1); adap->setmode(adap, 1); udelay(adap->mode); adap->setmode(adap, 0); udelay(adap->mode_setup); sendbyte(adap, addr); udelay(adap->mode_hold); sendbytes(adap, data, len); adap->setclk(adap, 1); adap->setdat(adap, 1); adap->setmode(adap, 0); return len; }

Contributors

PersonTokensPropCommitsCommitProp
Christian Pellegrin10988.62%150.00%
Sylwester Nawrocki1411.38%150.00%
Total123100.00%2100.00%

EXPORT_SYMBOL_GPL(l3_write);
static void l3_set_clk(struct l3_pins *adap, int val) { gpio_set_value(adap->gpio_clk, val); }

Contributors

PersonTokensPropCommitsCommitProp
Sylwester Nawrocki23100.00%1100.00%
Total23100.00%1100.00%


static void l3_set_data(struct l3_pins *adap, int val) { gpio_set_value(adap->gpio_data, val); }

Contributors

PersonTokensPropCommitsCommitProp
Sylwester Nawrocki23100.00%1100.00%
Total23100.00%1100.00%


static void l3_set_mode(struct l3_pins *adap, int val) { gpio_set_value(adap->gpio_mode, val); }

Contributors

PersonTokensPropCommitsCommitProp
Sylwester Nawrocki23100.00%1100.00%
Total23100.00%1100.00%


int l3_set_gpio_ops(struct device *dev, struct l3_pins *adap) { int ret; if (!adap->use_gpios) return -EINVAL; ret = devm_gpio_request_one(dev, adap->gpio_data, GPIOF_OUT_INIT_LOW, "l3_data"); if (ret < 0) return ret; adap->setdat = l3_set_data; ret = devm_gpio_request_one(dev, adap->gpio_clk, GPIOF_OUT_INIT_LOW, "l3_clk"); if (ret < 0) return ret; adap->setclk = l3_set_clk; ret = devm_gpio_request_one(dev, adap->gpio_mode, GPIOF_OUT_INIT_LOW, "l3_mode"); if (ret < 0) return ret; adap->setmode = l3_set_mode; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Sylwester Nawrocki122100.00%1100.00%
Total122100.00%1100.00%

EXPORT_SYMBOL_GPL(l3_set_gpio_ops); MODULE_DESCRIPTION("L3 bit-banging driver"); MODULE_AUTHOR("Christian Pellegrin <chripell@evolware.org>"); MODULE_LICENSE("GPL");

Overall Contributors

PersonTokensPropCommitsCommitProp
Christian Pellegrin31358.07%150.00%
Sylwester Nawrocki22641.93%150.00%
Total539100.00%2100.00%
Directory: sound/soc/codecs
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.