#include "chip.h"
#include "global1.h"
#include "global2.h"
#include "hwtstamp.h"
#include "ptp.h"
#define MV88E6XXX_MAX_ADJ_PPB …
struct mv88e6xxx_cc_coeffs { … };
#define MV88E6XXX_CC_10NS_SHIFT …
static const struct mv88e6xxx_cc_coeffs mv88e6xxx_cc_10ns_coeffs = …;
#define MV88E6XXX_CC_8NS_SHIFT …
static const struct mv88e6xxx_cc_coeffs mv88e6xxx_cc_8ns_coeffs = …;
#define MV88E6XXX_CC_4NS_SHIFT …
static const struct mv88e6xxx_cc_coeffs mv88e6xxx_cc_4ns_coeffs = …;
#define TAI_EVENT_WORK_INTERVAL …
#define cc_to_chip(cc) …
#define dw_overflow_to_chip(dw) …
#define dw_tai_event_to_chip(dw) …
static int mv88e6xxx_tai_read(struct mv88e6xxx_chip *chip, int addr,
u16 *data, int len)
{ … }
static int mv88e6xxx_tai_write(struct mv88e6xxx_chip *chip, int addr, u16 data)
{ … }
static int mv88e6352_set_gpio_func(struct mv88e6xxx_chip *chip, int pin,
int func, int input)
{ … }
static const struct mv88e6xxx_cc_coeffs *
mv88e6xxx_cc_coeff_get(struct mv88e6xxx_chip *chip)
{ … }
static u64 mv88e6352_ptp_clock_read(const struct cyclecounter *cc)
{ … }
static u64 mv88e6165_ptp_clock_read(const struct cyclecounter *cc)
{ … }
static int mv88e6352_config_eventcap(struct mv88e6xxx_chip *chip, int event,
int rising)
{ … }
static void mv88e6352_tai_event_work(struct work_struct *ugly)
{ … }
static int mv88e6xxx_ptp_adjfine(struct ptp_clock_info *ptp, long scaled_ppm)
{ … }
static int mv88e6xxx_ptp_adjtime(struct ptp_clock_info *ptp, s64 delta)
{ … }
static int mv88e6xxx_ptp_gettime(struct ptp_clock_info *ptp,
struct timespec64 *ts)
{ … }
static int mv88e6xxx_ptp_settime(struct ptp_clock_info *ptp,
const struct timespec64 *ts)
{ … }
static int mv88e6352_ptp_enable_extts(struct mv88e6xxx_chip *chip,
struct ptp_clock_request *rq, int on)
{ … }
static int mv88e6352_ptp_enable(struct ptp_clock_info *ptp,
struct ptp_clock_request *rq, int on)
{ … }
static int mv88e6352_ptp_verify(struct ptp_clock_info *ptp, unsigned int pin,
enum ptp_pin_function func, unsigned int chan)
{ … }
const struct mv88e6xxx_ptp_ops mv88e6165_ptp_ops = …;
const struct mv88e6xxx_ptp_ops mv88e6250_ptp_ops = …;
const struct mv88e6xxx_ptp_ops mv88e6352_ptp_ops = …;
const struct mv88e6xxx_ptp_ops mv88e6390_ptp_ops = …;
static u64 mv88e6xxx_ptp_clock_read(const struct cyclecounter *cc)
{ … }
#define MV88E6XXX_TAI_OVERFLOW_PERIOD …
static void mv88e6xxx_ptp_overflow_check(struct work_struct *work)
{ … }
int mv88e6xxx_ptp_setup(struct mv88e6xxx_chip *chip)
{ … }
void mv88e6xxx_ptp_free(struct mv88e6xxx_chip *chip)
{ … }