clk-lpss-atom.c 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Intel Low Power Subsystem clocks.
  4. *
  5. * Copyright (C) 2013, Intel Corporation
  6. * Authors: Mika Westerberg <[email protected]>
  7. * Heikki Krogerus <[email protected]>
  8. */
  9. #include <linux/clk-provider.h>
  10. #include <linux/err.h>
  11. #include <linux/module.h>
  12. #include <linux/platform_data/x86/clk-lpss.h>
  13. #include <linux/platform_device.h>
  14. static int lpss_atom_clk_probe(struct platform_device *pdev)
  15. {
  16. struct lpss_clk_data *drvdata;
  17. struct clk *clk;
  18. drvdata = devm_kzalloc(&pdev->dev, sizeof(*drvdata), GFP_KERNEL);
  19. if (!drvdata)
  20. return -ENOMEM;
  21. /* LPSS free running clock */
  22. drvdata->name = "lpss_clk";
  23. clk = clk_register_fixed_rate(&pdev->dev, drvdata->name, NULL,
  24. 0, 100000000);
  25. if (IS_ERR(clk))
  26. return PTR_ERR(clk);
  27. drvdata->clk = clk;
  28. platform_set_drvdata(pdev, drvdata);
  29. return 0;
  30. }
  31. static struct platform_driver lpss_atom_clk_driver = {
  32. .driver = {
  33. .name = "clk-lpss-atom",
  34. },
  35. .probe = lpss_atom_clk_probe,
  36. };
  37. int __init lpss_atom_clk_init(void)
  38. {
  39. return platform_driver_register(&lpss_atom_clk_driver);
  40. }