-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
yaml --- r: 83547 b: refs/heads/master c: ad8dc96 h: refs/heads/master i: 83545: 89dee38 83543: 0e613dd v: v3
- Loading branch information
Ville Syrjala
authored and
Linus Torvalds
committed
Feb 6, 2008
1 parent
a93607c
commit e147ec8
Showing
7 changed files
with
194 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
--- | ||
refs/heads/master: 4cdf854f7d60498bbda436068a118b95059b244b | ||
refs/heads/master: ad8dc96e3b2c3e28854e0de4ab49351ed547b30c |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
Kernel driver w1-gpio | ||
===================== | ||
|
||
Author: Ville Syrjala <syrjala@sci.fi> | ||
|
||
|
||
Description | ||
----------- | ||
|
||
GPIO 1-wire bus master driver. The driver uses the GPIO API to control the | ||
wire and the GPIO pin can be specified using platform data. | ||
|
||
|
||
Example (mach-at91) | ||
------------------- | ||
|
||
#include <linux/w1-gpio.h> | ||
|
||
static struct w1_gpio_platform_data foo_w1_gpio_pdata = { | ||
.pin = AT91_PIN_PB20, | ||
.is_open_drain = 1, | ||
}; | ||
|
||
static struct platform_device foo_w1_device = { | ||
.name = "w1-gpio", | ||
.id = -1, | ||
.dev.platform_data = &foo_w1_gpio_pdata, | ||
}; | ||
|
||
... | ||
at91_set_GPIO_periph(foo_w1_gpio_pdata.pin, 1); | ||
at91_set_multi_drive(foo_w1_gpio_pdata.pin, 1); | ||
platform_device_register(&foo_w1_device); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,124 @@ | ||
/* | ||
* w1-gpio - GPIO w1 bus master driver | ||
* | ||
* Copyright (C) 2007 Ville Syrjala <syrjala@sci.fi> | ||
* | ||
* 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. | ||
*/ | ||
|
||
#include <linux/init.h> | ||
#include <linux/module.h> | ||
#include <linux/platform_device.h> | ||
#include <linux/w1-gpio.h> | ||
|
||
#include "../w1.h" | ||
#include "../w1_int.h" | ||
|
||
#include <asm/gpio.h> | ||
|
||
static void w1_gpio_write_bit_dir(void *data, u8 bit) | ||
{ | ||
struct w1_gpio_platform_data *pdata = data; | ||
|
||
if (bit) | ||
gpio_direction_input(pdata->pin); | ||
else | ||
gpio_direction_output(pdata->pin, 0); | ||
} | ||
|
||
static void w1_gpio_write_bit_val(void *data, u8 bit) | ||
{ | ||
struct w1_gpio_platform_data *pdata = data; | ||
|
||
gpio_set_value(pdata->pin, bit); | ||
} | ||
|
||
static u8 w1_gpio_read_bit(void *data) | ||
{ | ||
struct w1_gpio_platform_data *pdata = data; | ||
|
||
return gpio_get_value(pdata->pin); | ||
} | ||
|
||
static int __init w1_gpio_probe(struct platform_device *pdev) | ||
{ | ||
struct w1_bus_master *master; | ||
struct w1_gpio_platform_data *pdata = pdev->dev.platform_data; | ||
int err; | ||
|
||
if (!pdata) | ||
return -ENXIO; | ||
|
||
master = kzalloc(sizeof(struct w1_bus_master), GFP_KERNEL); | ||
if (!master) | ||
return -ENOMEM; | ||
|
||
err = gpio_request(pdata->pin, "w1"); | ||
if (err) | ||
goto free_master; | ||
|
||
master->data = pdata; | ||
master->read_bit = w1_gpio_read_bit; | ||
|
||
if (pdata->is_open_drain) { | ||
gpio_direction_output(pdata->pin, 1); | ||
master->write_bit = w1_gpio_write_bit_val; | ||
} else { | ||
gpio_direction_input(pdata->pin); | ||
master->write_bit = w1_gpio_write_bit_dir; | ||
} | ||
|
||
err = w1_add_master_device(master); | ||
if (err) | ||
goto free_gpio; | ||
|
||
platform_set_drvdata(pdev, master); | ||
|
||
return 0; | ||
|
||
free_gpio: | ||
gpio_free(pdata->pin); | ||
free_master: | ||
kfree(master); | ||
|
||
return err; | ||
} | ||
|
||
static int __exit w1_gpio_remove(struct platform_device *pdev) | ||
{ | ||
struct w1_bus_master *master = platform_get_drvdata(pdev); | ||
struct w1_gpio_platform_data *pdata = pdev->dev.platform_data; | ||
|
||
w1_remove_master_device(master); | ||
gpio_free(pdata->pin); | ||
kfree(master); | ||
|
||
return 0; | ||
} | ||
|
||
static struct platform_driver w1_gpio_driver = { | ||
.driver = { | ||
.name = "w1-gpio", | ||
.owner = THIS_MODULE, | ||
}, | ||
.remove = __exit_p(w1_gpio_remove), | ||
}; | ||
|
||
static int __init w1_gpio_init(void) | ||
{ | ||
return platform_driver_probe(&w1_gpio_driver, w1_gpio_probe); | ||
} | ||
|
||
static void __exit w1_gpio_exit(void) | ||
{ | ||
platform_driver_unregister(&w1_gpio_driver); | ||
} | ||
|
||
module_init(w1_gpio_init); | ||
module_exit(w1_gpio_exit); | ||
|
||
MODULE_DESCRIPTION("GPIO w1 bus master driver"); | ||
MODULE_AUTHOR("Ville Syrjala <syrjala@sci.fi>"); | ||
MODULE_LICENSE("GPL"); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
/* | ||
* w1-gpio interface to platform code | ||
* | ||
* Copyright (C) 2007 Ville Syrjala <syrjala@sci.fi> | ||
* | ||
* 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. | ||
*/ | ||
#ifndef _LINUX_W1_GPIO_H | ||
#define _LINUX_W1_GPIO_H | ||
|
||
/** | ||
* struct w1_gpio_platform_data - Platform-dependent data for w1-gpio | ||
* @pin: GPIO pin to use | ||
* @is_open_drain: GPIO pin is configured as open drain | ||
*/ | ||
struct w1_gpio_platform_data { | ||
unsigned int pin; | ||
unsigned int is_open_drain:1; | ||
}; | ||
|
||
#endif /* _LINUX_W1_GPIO_H */ |