mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 10:00:17 +00:00
Added support to reserve/enable a GPIO pin to be used from pps-gpio module (LinuxPPS). Enable PPS modules in default config for RPi.
This commit is contained in:
committed by
popcornmix
parent
c5fa77a48c
commit
c407412c16
@@ -37,6 +37,7 @@
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/gpio/machine.h>
|
||||
#include <linux/w1-gpio.h>
|
||||
#include <linux/pps-gpio.h>
|
||||
|
||||
#include <linux/version.h>
|
||||
#include <linux/clkdev.h>
|
||||
@@ -93,6 +94,7 @@ static unsigned disk_led_active_low = 1;
|
||||
static unsigned reboot_part = 0;
|
||||
static unsigned w1_gpio_pin = W1_GPIO;
|
||||
static unsigned w1_gpio_pullup = W1_PULLUP;
|
||||
static int pps_gpio_pin = -1;
|
||||
|
||||
static unsigned use_dt = 0;
|
||||
|
||||
@@ -278,6 +280,19 @@ static struct platform_device w1_device = {
|
||||
};
|
||||
#endif
|
||||
|
||||
static struct pps_gpio_platform_data pps_gpio_info = {
|
||||
.assert_falling_edge = false,
|
||||
.capture_clear = false,
|
||||
.gpio_pin = -1,
|
||||
.gpio_label = "PPS",
|
||||
};
|
||||
|
||||
static struct platform_device pps_gpio_device = {
|
||||
.name = "pps-gpio",
|
||||
.id = PLATFORM_DEVID_NONE,
|
||||
.dev.platform_data = &pps_gpio_info,
|
||||
};
|
||||
|
||||
static u64 fb_dmamask = DMA_BIT_MASK(DMA_MASK_BITS_COMMON);
|
||||
|
||||
static struct platform_device bcm2708_fb_device = {
|
||||
@@ -846,6 +861,16 @@ void __init bcm2708_init(void)
|
||||
#ifdef CONFIG_BCM2708_GPIO
|
||||
bcm_register_device_dt(&bcm2708_gpio_device);
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_PPS_CLIENT_GPIO) || defined(CONFIG_PPS_CLIENT_GPIO_MODULE)
|
||||
if (!use_dt && (pps_gpio_pin >= 0)) {
|
||||
pr_info("bcm2708: GPIO %d setup as pps-gpio device\n", pps_gpio_pin);
|
||||
pps_gpio_info.gpio_pin = pps_gpio_pin;
|
||||
pps_gpio_device.id = pps_gpio_pin;
|
||||
bcm_register_device(&pps_gpio_device);
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_W1_MASTER_GPIO) || defined(CONFIG_W1_MASTER_GPIO_MODULE)
|
||||
w1_gpio_pdata.pin = w1_gpio_pin;
|
||||
w1_gpio_pdata.ext_pullup_enable_pin = w1_gpio_pullup;
|
||||
@@ -1099,3 +1124,5 @@ module_param(disk_led_active_low, uint, 0644);
|
||||
module_param(reboot_part, uint, 0644);
|
||||
module_param(w1_gpio_pin, uint, 0644);
|
||||
module_param(w1_gpio_pullup, uint, 0644);
|
||||
module_param(pps_gpio_pin, int, 0644);
|
||||
MODULE_PARM_DESC(pps_gpio_pin, "Set GPIO pin to reserve for PPS");
|
||||
|
||||
@@ -37,6 +37,7 @@
|
||||
#include <linux/spi/spi.h>
|
||||
#include <linux/gpio/machine.h>
|
||||
#include <linux/w1-gpio.h>
|
||||
#include <linux/pps-gpio.h>
|
||||
|
||||
#include <linux/version.h>
|
||||
#include <linux/clkdev.h>
|
||||
@@ -95,6 +96,7 @@ static unsigned disk_led_active_low = 1;
|
||||
static unsigned reboot_part = 0;
|
||||
static unsigned w1_gpio_pin = W1_GPIO;
|
||||
static unsigned w1_gpio_pullup = W1_PULLUP;
|
||||
static int pps_gpio_pin = -1;
|
||||
|
||||
static unsigned use_dt = 0;
|
||||
|
||||
@@ -288,6 +290,19 @@ static struct platform_device w1_device = {
|
||||
};
|
||||
#endif
|
||||
|
||||
static struct pps_gpio_platform_data pps_gpio_info = {
|
||||
.assert_falling_edge = false,
|
||||
.capture_clear = false,
|
||||
.gpio_pin = -1,
|
||||
.gpio_label = "PPS",
|
||||
};
|
||||
|
||||
static struct platform_device pps_gpio_device = {
|
||||
.name = "pps-gpio",
|
||||
.id = PLATFORM_DEVID_NONE,
|
||||
.dev.platform_data = &pps_gpio_info,
|
||||
};
|
||||
|
||||
static u64 fb_dmamask = DMA_BIT_MASK(DMA_MASK_BITS_COMMON);
|
||||
|
||||
static struct platform_device bcm2708_fb_device = {
|
||||
@@ -868,6 +883,16 @@ void __init bcm2709_init(void)
|
||||
#ifdef CONFIG_BCM2708_GPIO
|
||||
bcm_register_device_dt(&bcm2708_gpio_device);
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_PPS_CLIENT_GPIO) || defined(CONFIG_PPS_CLIENT_GPIO_MODULE)
|
||||
if (!use_dt && (pps_gpio_pin >= 0)) {
|
||||
pr_info("bcm2709: GPIO %d setup as pps-gpio device\n", pps_gpio_pin);
|
||||
pps_gpio_info.gpio_pin = pps_gpio_pin;
|
||||
pps_gpio_device.id = pps_gpio_pin;
|
||||
bcm_register_device(&pps_gpio_device);
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(CONFIG_W1_MASTER_GPIO) || defined(CONFIG_W1_MASTER_GPIO_MODULE)
|
||||
w1_gpio_pdata.pin = w1_gpio_pin;
|
||||
w1_gpio_pdata.ext_pullup_enable_pin = w1_gpio_pullup;
|
||||
@@ -1267,3 +1292,5 @@ module_param(disk_led_active_low, uint, 0644);
|
||||
module_param(reboot_part, uint, 0644);
|
||||
module_param(w1_gpio_pin, uint, 0644);
|
||||
module_param(w1_gpio_pullup, uint, 0644);
|
||||
module_param(pps_gpio_pin, int, 0644);
|
||||
MODULE_PARM_DESC(pps_gpio_pin, "Set GPIO pin to reserve for PPS");
|
||||
|
||||
Reference in New Issue
Block a user