gdsys_rxaui_ctrl.c 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2015
  4. * Dirk Eibach, Guntermann & Drunck GmbH, eibach@gdsys.de
  5. *
  6. * (C) Copyright 2017
  7. * Mario Six, Guntermann & Drunck GmbH, mario.six@gdsys.cc
  8. */
  9. #include <common.h>
  10. #include <dm.h>
  11. #include <regmap.h>
  12. #include <misc.h>
  13. struct gdsys_rxaui_ctrl_regs {
  14. u16 gen_cnt;
  15. u16 err_cnt;
  16. u16 succ_cnt;
  17. u16 status;
  18. u16 ctrl_0;
  19. u16 ctrl_1;
  20. };
  21. #define rxaui_ctrl_set(map, member, val) \
  22. regmap_set(map, struct gdsys_rxaui_ctrl_regs, member, val)
  23. #define rxaui_ctrl_get(map, member, valp) \
  24. regmap_get(map, struct gdsys_rxaui_ctrl_regs, member, valp)
  25. struct gdsys_rxaui_ctrl_priv {
  26. struct regmap *map;
  27. };
  28. int gdsys_rxaui_set_polarity_inversion(struct udevice *dev, bool val)
  29. {
  30. struct gdsys_rxaui_ctrl_priv *priv = dev_get_priv(dev);
  31. u16 state;
  32. rxaui_ctrl_get(priv->map, ctrl_1, &state);
  33. if (val)
  34. state |= ~0x7800;
  35. else
  36. state &= ~0x7800;
  37. rxaui_ctrl_set(priv->map, ctrl_1, state);
  38. return 0;
  39. }
  40. static const struct misc_ops gdsys_rxaui_ctrl_ops = {
  41. .set_enabled = gdsys_rxaui_set_polarity_inversion,
  42. };
  43. int gdsys_rxaui_ctrl_probe(struct udevice *dev)
  44. {
  45. struct gdsys_rxaui_ctrl_priv *priv = dev_get_priv(dev);
  46. regmap_init_mem(dev, &priv->map);
  47. return 0;
  48. }
  49. static const struct udevice_id gdsys_rxaui_ctrl_ids[] = {
  50. { .compatible = "gdsys,rxaui_ctrl" },
  51. { }
  52. };
  53. U_BOOT_DRIVER(gdsys_rxaui_ctrl) = {
  54. .name = "gdsys_rxaui_ctrl",
  55. .id = UCLASS_MISC,
  56. .ops = &gdsys_rxaui_ctrl_ops,
  57. .of_match = gdsys_rxaui_ctrl_ids,
  58. .probe = gdsys_rxaui_ctrl_probe,
  59. .priv_auto_alloc_size = sizeof(struct gdsys_rxaui_ctrl_priv),
  60. };