xref: /linux-6.15/include/linux/pps_kernel.h (revision 5e196d34)
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 
34*5e196d34SAlexander Gordeev struct pps_device;
35*5e196d34SAlexander 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 
42*5e196d34SAlexander Gordeev 	void (*echo)(struct pps_device *pps,
43*5e196d34SAlexander 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 {
506f4229b5SAlexander Gordeev 	struct timespec ts_real;
516f4229b5SAlexander Gordeev };
526f4229b5SAlexander Gordeev 
53eae9d2baSRodolfo Giometti /* The main struct */
54eae9d2baSRodolfo Giometti struct pps_device {
55eae9d2baSRodolfo Giometti 	struct pps_source_info info;		/* PSS source info */
56eae9d2baSRodolfo Giometti 
57eae9d2baSRodolfo Giometti 	struct pps_kparams params;		/* PPS's current params */
58eae9d2baSRodolfo Giometti 
59eae9d2baSRodolfo Giometti 	__u32 assert_sequence;			/* PPS' assert event seq # */
60eae9d2baSRodolfo Giometti 	__u32 clear_sequence;			/* PPS' clear event seq # */
61eae9d2baSRodolfo Giometti 	struct pps_ktime assert_tu;
62eae9d2baSRodolfo Giometti 	struct pps_ktime clear_tu;
63eae9d2baSRodolfo Giometti 	int current_mode;			/* PPS mode at event time */
64eae9d2baSRodolfo Giometti 
653003d55bSAlexander Gordeev 	unsigned int last_ev;			/* last PPS event id */
66eae9d2baSRodolfo Giometti 	wait_queue_head_t queue;		/* PPS event queue */
67eae9d2baSRodolfo Giometti 
68eae9d2baSRodolfo Giometti 	unsigned int id;			/* PPS source unique ID */
69eae9d2baSRodolfo Giometti 	struct cdev cdev;
70eae9d2baSRodolfo Giometti 	struct device *dev;
71eae9d2baSRodolfo Giometti 	struct fasync_struct *async_queue;	/* fasync method */
72eae9d2baSRodolfo Giometti 	spinlock_t lock;
73eae9d2baSRodolfo Giometti };
74eae9d2baSRodolfo Giometti 
75eae9d2baSRodolfo Giometti /*
76eae9d2baSRodolfo Giometti  * Global variables
77eae9d2baSRodolfo Giometti  */
78eae9d2baSRodolfo Giometti 
79eae9d2baSRodolfo Giometti extern struct device_attribute pps_attrs[];
80eae9d2baSRodolfo Giometti 
81eae9d2baSRodolfo Giometti /*
82eae9d2baSRodolfo Giometti  * Exported functions
83eae9d2baSRodolfo Giometti  */
84eae9d2baSRodolfo Giometti 
85*5e196d34SAlexander Gordeev extern struct pps_device *pps_register_source(
86*5e196d34SAlexander Gordeev 		struct pps_source_info *info, int default_params);
87*5e196d34SAlexander Gordeev extern void pps_unregister_source(struct pps_device *pps);
88eae9d2baSRodolfo Giometti extern int pps_register_cdev(struct pps_device *pps);
89eae9d2baSRodolfo Giometti extern void pps_unregister_cdev(struct pps_device *pps);
90*5e196d34SAlexander Gordeev extern void pps_event(struct pps_device *pps,
91*5e196d34SAlexander Gordeev 		struct pps_event_time *ts, int event, void *data);
926f4229b5SAlexander Gordeev 
936f4229b5SAlexander Gordeev static inline void timespec_to_pps_ktime(struct pps_ktime *kt,
946f4229b5SAlexander Gordeev 		struct timespec ts)
956f4229b5SAlexander Gordeev {
966f4229b5SAlexander Gordeev 	kt->sec = ts.tv_sec;
976f4229b5SAlexander Gordeev 	kt->nsec = ts.tv_nsec;
986f4229b5SAlexander Gordeev }
996f4229b5SAlexander Gordeev 
1006f4229b5SAlexander Gordeev static inline void pps_get_ts(struct pps_event_time *ts)
1016f4229b5SAlexander Gordeev {
1026f4229b5SAlexander Gordeev 	getnstimeofday(&ts->ts_real);
1036f4229b5SAlexander Gordeev }
1047a21a3ccSAlexander Gordeev 
1057a21a3ccSAlexander Gordeev #endif /* LINUX_PPS_KERNEL_H */
1066f4229b5SAlexander Gordeev 
107