Separate required_modes setting from clock_create so we can obtain the
required time stamping flags from other place.

Add enum timestamping in struct clock to store the time stamping mode.

Signed-off-by: Hangbin Liu <liuhang...@gmail.com>
---
 clock.c | 49 +++++++++++++++++++++++++++++++------------------
 clock.h |  8 ++++++++
 2 files changed, 39 insertions(+), 18 deletions(-)

diff --git a/clock.c b/clock.c
index da15882..bd2b91b 100644
--- a/clock.c
+++ b/clock.c
@@ -106,6 +106,7 @@ struct clock {
        int time_flags;  /* grand master role */
        int time_source; /* grand master role */
        enum servo_state servo_state;
+       enum timestamp_type timestamping;
        tmv_t master_offset;
        tmv_t path_delay;
        tmv_t ingress_ts;
@@ -805,6 +806,34 @@ static void clock_remove_port(struct clock *c, struct port 
*p)
        port_close(p);
 }
 
+int clock_required_modes(struct clock *c)
+{
+       int required_modes = 0;
+
+       switch (c->timestamping) {
+       case TS_SOFTWARE:
+               required_modes |= SOF_TIMESTAMPING_TX_SOFTWARE |
+                       SOF_TIMESTAMPING_RX_SOFTWARE |
+                       SOF_TIMESTAMPING_SOFTWARE;
+               break;
+       case TS_LEGACY_HW:
+               required_modes |= SOF_TIMESTAMPING_TX_HARDWARE |
+                       SOF_TIMESTAMPING_RX_HARDWARE |
+                       SOF_TIMESTAMPING_SYS_HARDWARE;
+               break;
+       case TS_HARDWARE:
+       case TS_ONESTEP:
+               required_modes |= SOF_TIMESTAMPING_TX_HARDWARE |
+                       SOF_TIMESTAMPING_RX_HARDWARE |
+                       SOF_TIMESTAMPING_RAW_HARDWARE;
+               break;
+       default:
+               break;
+       }
+
+       return required_modes;
+}
+
 struct clock *clock_create(enum clock_type type, struct config *config,
                           const char *phc_device)
 {
@@ -913,24 +942,8 @@ struct clock *clock_create(enum clock_type type, struct 
config *config,
        }
 
        /* Check the time stamping mode on each interface. */
-       switch (timestamping) {
-       case TS_SOFTWARE:
-               required_modes |= SOF_TIMESTAMPING_TX_SOFTWARE |
-                       SOF_TIMESTAMPING_RX_SOFTWARE |
-                       SOF_TIMESTAMPING_SOFTWARE;
-               break;
-       case TS_LEGACY_HW:
-               required_modes |= SOF_TIMESTAMPING_TX_HARDWARE |
-                       SOF_TIMESTAMPING_RX_HARDWARE |
-                       SOF_TIMESTAMPING_SYS_HARDWARE;
-               break;
-       case TS_HARDWARE:
-       case TS_ONESTEP:
-               required_modes |= SOF_TIMESTAMPING_TX_HARDWARE |
-                       SOF_TIMESTAMPING_RX_HARDWARE |
-                       SOF_TIMESTAMPING_RAW_HARDWARE;
-               break;
-       }
+       c->timestamping = timestamping;
+       required_modes = clock_required_modes(c);
        STAILQ_FOREACH(iface, &config->interfaces, list) {
                if (iface->ts_info.valid &&
                    ((iface->ts_info.so_timestamping & required_modes) != 
required_modes)) {
diff --git a/clock.h b/clock.h
index 49ecb76..986d363 100644
--- a/clock.h
+++ b/clock.h
@@ -73,6 +73,14 @@ UInteger8 clock_class(struct clock *c);
 struct config *clock_config(struct clock *c);
 
 /**
+ * Obtains the required time stamping mode.
+ * @param c  The clock instance.
+ * @return   The value of required time stamping mode, which is a bit mask
+ *           of SOF_TIMESTAMPING_ flags.
+ */
+int clock_required_modes(struct clock *c);
+
+/**
  * Create a clock instance. There can only be one clock in any system,
  * so subsequent calls will destroy the previous clock instance.
  *
-- 
2.5.5


------------------------------------------------------------------------------
Check out the vibrant tech community on one of the world's most
engaging tech sites, Slashdot.org! http://sdm.link/slashdot
_______________________________________________
Linuxptp-devel mailing list
Linuxptp-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linuxptp-devel

Reply via email to