xref: /linux-6.15/include/linux/pps_kernel.h (revision e2c18e49)
1eae9d2baSRodolfo Giometti /*
2eae9d2baSRodolfo Giometti  * PPS API kernel header
3eae9d2baSRodolfo Giometti  *
4eae9d2baSRodolfo Giometti  * Copyright (C) 2009   Rodolfo Giometti <[email protected]>
5eae9d2baSRodolfo Giometti  *
6eae9d2baSRodolfo Giometti  *   This program is free software; you can redistribute it and/or modify
7eae9d2baSRodolfo Giometti  *   it under the terms of the GNU General Public License as published by
8eae9d2baSRodolfo Giometti  *   the Free Software Foundation; either version 2 of the License, or
9eae9d2baSRodolfo Giometti  *   (at your option) any later version.
10eae9d2baSRodolfo Giometti  *
11eae9d2baSRodolfo Giometti  *   This program is distributed in the hope that it will be useful,
12eae9d2baSRodolfo Giometti  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
13eae9d2baSRodolfo Giometti  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14eae9d2baSRodolfo Giometti  *   GNU General Public License for more details.
15eae9d2baSRodolfo Giometti  *
16eae9d2baSRodolfo Giometti  *   You should have received a copy of the GNU General Public License
17eae9d2baSRodolfo Giometti  *   along with this program; if not, write to the Free Software
18eae9d2baSRodolfo Giometti  *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19eae9d2baSRodolfo Giometti  */
20eae9d2baSRodolfo Giometti 
217a21a3ccSAlexander Gordeev #ifndef LINUX_PPS_KERNEL_H
227a21a3ccSAlexander Gordeev #define LINUX_PPS_KERNEL_H
237a21a3ccSAlexander Gordeev 
24eae9d2baSRodolfo Giometti #include <linux/pps.h>
25eae9d2baSRodolfo Giometti 
26eae9d2baSRodolfo Giometti #include <linux/cdev.h>
27eae9d2baSRodolfo Giometti #include <linux/device.h>
28eae9d2baSRodolfo Giometti #include <linux/time.h>
29eae9d2baSRodolfo Giometti 
30eae9d2baSRodolfo Giometti /*
31eae9d2baSRodolfo Giometti  * Global defines
32eae9d2baSRodolfo Giometti  */
33eae9d2baSRodolfo Giometti 
345e196d34SAlexander Gordeev struct pps_device;
355e196d34SAlexander Gordeev 
36eae9d2baSRodolfo Giometti /* The specific PPS source info */
37eae9d2baSRodolfo Giometti struct pps_source_info {
38eae9d2baSRodolfo Giometti 	char name[PPS_MAX_NAME_LEN];		/* simbolic name */
39eae9d2baSRodolfo Giometti 	char path[PPS_MAX_NAME_LEN];		/* path of connected device */
40eae9d2baSRodolfo Giometti 	int mode;				/* PPS's allowed mode */
41eae9d2baSRodolfo Giometti 
425e196d34SAlexander Gordeev 	void (*echo)(struct pps_device *pps,
435e196d34SAlexander Gordeev 			int event, void *data);	/* PPS echo function */
44eae9d2baSRodolfo Giometti 
45eae9d2baSRodolfo Giometti 	struct module *owner;
46eae9d2baSRodolfo Giometti 	struct device *dev;
47eae9d2baSRodolfo Giometti };
48eae9d2baSRodolfo Giometti 
496f4229b5SAlexander Gordeev struct pps_event_time {
50*e2c18e49SAlexander Gordeev #ifdef CONFIG_NTP_PPS
51*e2c18e49SAlexander Gordeev 	struct timespec ts_raw;
52*e2c18e49SAlexander Gordeev #endif /* CONFIG_NTP_PPS */
536f4229b5SAlexander Gordeev 	struct timespec ts_real;
546f4229b5SAlexander Gordeev };
556f4229b5SAlexander Gordeev 
56eae9d2baSRodolfo Giometti /* The main struct */
57eae9d2baSRodolfo Giometti struct pps_device {
58eae9d2baSRodolfo Giometti 	struct pps_source_info info;		/* PSS source info */
59eae9d2baSRodolfo Giometti 
60eae9d2baSRodolfo Giometti 	struct pps_kparams params;		/* PPS's current params */
61eae9d2baSRodolfo Giometti 
62eae9d2baSRodolfo Giometti 	__u32 assert_sequence;			/* PPS' assert event seq # */
63eae9d2baSRodolfo Giometti 	__u32 clear_sequence;			/* PPS' clear event seq # */
64eae9d2baSRodolfo Giometti 	struct pps_ktime assert_tu;
65eae9d2baSRodolfo Giometti 	struct pps_ktime clear_tu;
66eae9d2baSRodolfo Giometti 	int current_mode;			/* PPS mode at event time */
67eae9d2baSRodolfo Giometti 
683003d55bSAlexander Gordeev 	unsigned int last_ev;			/* last PPS event id */
69eae9d2baSRodolfo Giometti 	wait_queue_head_t queue;		/* PPS event queue */
70eae9d2baSRodolfo Giometti 
71eae9d2baSRodolfo Giometti 	unsigned int id;			/* PPS source unique ID */
72eae9d2baSRodolfo Giometti 	struct cdev cdev;
73eae9d2baSRodolfo Giometti 	struct device *dev;
74eae9d2baSRodolfo Giometti 	struct fasync_struct *async_queue;	/* fasync method */
75eae9d2baSRodolfo Giometti 	spinlock_t lock;
76eae9d2baSRodolfo Giometti };
77eae9d2baSRodolfo Giometti 
78eae9d2baSRodolfo Giometti /*
79eae9d2baSRodolfo Giometti  * Global variables
80eae9d2baSRodolfo Giometti  */
81eae9d2baSRodolfo Giometti 
82eae9d2baSRodolfo Giometti extern struct device_attribute pps_attrs[];
83eae9d2baSRodolfo Giometti 
84eae9d2baSRodolfo Giometti /*
85eae9d2baSRodolfo Giometti  * Exported functions
86eae9d2baSRodolfo Giometti  */
87eae9d2baSRodolfo Giometti 
885e196d34SAlexander Gordeev extern struct pps_device *pps_register_source(
895e196d34SAlexander Gordeev 		struct pps_source_info *info, int default_params);
905e196d34SAlexander Gordeev extern void pps_unregister_source(struct pps_device *pps);
91eae9d2baSRodolfo Giometti extern int pps_register_cdev(struct pps_device *pps);
92eae9d2baSRodolfo Giometti extern void pps_unregister_cdev(struct pps_device *pps);
935e196d34SAlexander Gordeev extern void pps_event(struct pps_device *pps,
945e196d34SAlexander Gordeev 		struct pps_event_time *ts, int event, void *data);
956f4229b5SAlexander Gordeev 
966f4229b5SAlexander Gordeev static inline void timespec_to_pps_ktime(struct pps_ktime *kt,
976f4229b5SAlexander Gordeev 		struct timespec ts)
986f4229b5SAlexander Gordeev {
996f4229b5SAlexander Gordeev 	kt->sec = ts.tv_sec;
1006f4229b5SAlexander Gordeev 	kt->nsec = ts.tv_nsec;
1016f4229b5SAlexander Gordeev }
1026f4229b5SAlexander Gordeev 
103*e2c18e49SAlexander Gordeev #ifdef CONFIG_NTP_PPS
104*e2c18e49SAlexander Gordeev 
105*e2c18e49SAlexander Gordeev static inline void pps_get_ts(struct pps_event_time *ts)
106*e2c18e49SAlexander Gordeev {
107*e2c18e49SAlexander Gordeev 	getnstime_raw_and_real(&ts->ts_raw, &ts->ts_real);
108*e2c18e49SAlexander Gordeev }
109*e2c18e49SAlexander Gordeev 
110*e2c18e49SAlexander Gordeev #else /* CONFIG_NTP_PPS */
111*e2c18e49SAlexander Gordeev 
1126f4229b5SAlexander Gordeev static inline void pps_get_ts(struct pps_event_time *ts)
1136f4229b5SAlexander Gordeev {
1146f4229b5SAlexander Gordeev 	getnstimeofday(&ts->ts_real);
1156f4229b5SAlexander Gordeev }
1167a21a3ccSAlexander Gordeev 
117*e2c18e49SAlexander Gordeev #endif /* CONFIG_NTP_PPS */
118*e2c18e49SAlexander Gordeev 
1197a21a3ccSAlexander Gordeev #endif /* LINUX_PPS_KERNEL_H */
1206f4229b5SAlexander Gordeev 
121