Blame view

include/cpu.h 3.8 KB
83d290c56   Tom Rini   SPDX: Convert all...
1
  /* SPDX-License-Identifier: GPL-2.0+ */
11f4dc158   Simon Glass   dm: Implement a C...
2
3
4
  /*
   * Copyright (c) 2015 Google, Inc
   * Written by Simon Glass <sjg@chromium.org>
11f4dc158   Simon Glass   dm: Implement a C...
5
6
7
8
9
10
11
   */
  
  #ifndef __CPU_H
  #define __CPU_H
  
  /**
   * struct cpu_platdata - platform data for a CPU
50d188b95   Mario Six   cpu: Fix cpu.h do...
12
13
14
15
16
   * @cpu_id:	   Platform-specific way of identifying the CPU.
   * @ucode_version: Microcode version, if CPU_FEAT_UCODE is set
   * @device_id:     Driver-defined device identifier
   * @family:        DMTF CPU Family identifier
   * @id:            DMTF CPU Processor identifier
b85969477   Bin Meng   dm: cpu: Add time...
17
18
   * @timebase_freq: the current frequency at which the cpu timer timebase
   *		   registers are updated (in Hz)
11f4dc158   Simon Glass   dm: Implement a C...
19
20
21
   *
   * This can be accessed with dev_get_parent_platdata() for any UCLASS_CPU
   * device.
11f4dc158   Simon Glass   dm: Implement a C...
22
23
24
   */
  struct cpu_platdata {
  	int cpu_id;
740d5d34b   Simon Glass   cpu: Add support ...
25
26
  	int ucode_version;
  	ulong device_id;
50d188b95   Mario Six   cpu: Fix cpu.h do...
27
28
  	u16 family;
  	u32 id[2];
b85969477   Bin Meng   dm: cpu: Add time...
29
  	u32 timebase_freq;
11f4dc158   Simon Glass   dm: Implement a C...
30
31
32
33
34
35
  };
  
  /* CPU features - mostly just a placeholder for now */
  enum {
  	CPU_FEAT_L1_CACHE	= 0,	/* Supports level 1 cache */
  	CPU_FEAT_MMU		= 1,	/* Supports virtual memory */
740d5d34b   Simon Glass   cpu: Add support ...
36
37
  	CPU_FEAT_UCODE		= 2,	/* Requires/uses microcode */
  	CPU_FEAT_DEVICE_ID	= 3,	/* Provides a device ID */
11f4dc158   Simon Glass   dm: Implement a C...
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
  
  	CPU_FEAT_COUNT,
  };
  
  /**
   * struct cpu_info - Information about a CPU
   *
   * @cpu_freq:	Current CPU frequency in Hz
   * @features:	Flags for supported CPU features
   */
  struct cpu_info {
  	ulong cpu_freq;
  	ulong features;
  };
  
  struct cpu_ops {
  	/**
  	 * get_desc() - Get a description string for a CPU
  	 *
  	 * @dev:	Device to check (UCLASS_CPU)
  	 * @buf:	Buffer to place string
  	 * @size:	Size of string space
  	 * @return 0 if OK, -ENOSPC if buffer is too small, other -ve on error
  	 */
  	int (*get_desc)(struct udevice *dev, char *buf, int size);
  
  	/**
  	 * get_info() - Get information about a CPU
  	 *
  	 * @dev:	Device to check (UCLASS_CPU)
  	 * @info:	Returns CPU info
  	 * @return 0 if OK, -ve on error
  	 */
  	int (*get_info)(struct udevice *dev, struct cpu_info *info);
780bfdd3c   Bin Meng   dm: cpu: Add a ne...
72
73
74
75
76
77
78
79
  
  	/**
  	 * get_count() - Get number of CPUs
  	 *
  	 * @dev:	Device to check (UCLASS_CPU)
  	 * @return CPU count if OK, -ve on error
  	 */
  	int (*get_count)(struct udevice *dev);
94eaa79ce   Alexander Graf   cpu: Add get_vend...
80
81
82
83
84
85
86
87
88
89
  
  	/**
  	 * get_vendor() - Get vendor name of a CPU
  	 *
  	 * @dev:	Device to check (UCLASS_CPU)
  	 * @buf:	Buffer to place string
  	 * @size:	Size of string space
  	 * @return 0 if OK, -ENOSPC if buffer is too small, other -ve on error
  	 */
  	int (*get_vendor)(struct udevice *dev, char *buf, int size);
c764f454a   Ye Li   MLK-21828-1 uclas...
90
91
92
93
94
95
96
97
  
  	/**
  	 * is_current_cpu() - Check if the device is for current CPU
  	 *
  	 * @dev:	Device to check (UCLASS_CPU)
  	 * @return true if the device is current CPU, false if the device is not.
  	 */
  	bool (*is_current_cpu)(struct udevice *dev);
11f4dc158   Simon Glass   dm: Implement a C...
98
99
100
101
102
103
  };
  
  #define cpu_get_ops(dev)        ((struct cpu_ops *)(dev)->driver->ops)
  
  /**
   * cpu_get_desc() - Get a description string for a CPU
11f4dc158   Simon Glass   dm: Implement a C...
104
105
106
   * @dev:	Device to check (UCLASS_CPU)
   * @buf:	Buffer to place string
   * @size:	Size of string space
50d188b95   Mario Six   cpu: Fix cpu.h do...
107
108
   *
   * Return: 0 if OK, -ENOSPC if buffer is too small, other -ve on error
11f4dc158   Simon Glass   dm: Implement a C...
109
110
111
112
113
   */
  int cpu_get_desc(struct udevice *dev, char *buf, int size);
  
  /**
   * cpu_get_info() - Get information about a CPU
11f4dc158   Simon Glass   dm: Implement a C...
114
115
   * @dev:	Device to check (UCLASS_CPU)
   * @info:	Returns CPU info
50d188b95   Mario Six   cpu: Fix cpu.h do...
116
117
   *
   * Return: 0 if OK, -ve on error
11f4dc158   Simon Glass   dm: Implement a C...
118
119
   */
  int cpu_get_info(struct udevice *dev, struct cpu_info *info);
780bfdd3c   Bin Meng   dm: cpu: Add a ne...
120
121
  /**
   * cpu_get_count() - Get number of CPUs
780bfdd3c   Bin Meng   dm: cpu: Add a ne...
122
   * @dev:	Device to check (UCLASS_CPU)
50d188b95   Mario Six   cpu: Fix cpu.h do...
123
124
   *
   * Return: CPU count if OK, -ve on error
780bfdd3c   Bin Meng   dm: cpu: Add a ne...
125
126
   */
  int cpu_get_count(struct udevice *dev);
94eaa79ce   Alexander Graf   cpu: Add get_vend...
127
128
  /**
   * cpu_get_vendor() - Get vendor name of a CPU
94eaa79ce   Alexander Graf   cpu: Add get_vend...
129
130
131
   * @dev:	Device to check (UCLASS_CPU)
   * @buf:	Buffer to place string
   * @size:	Size of string space
50d188b95   Mario Six   cpu: Fix cpu.h do...
132
133
   *
   * Return: 0 if OK, -ENOSPC if buffer is too small, other -ve on error
94eaa79ce   Alexander Graf   cpu: Add get_vend...
134
135
   */
  int cpu_get_vendor(struct udevice *dev, char *buf, int size);
57370de37   Mario Six   cpu: Add cpu_prob...
136
137
138
139
140
141
  /**
   * cpu_probe_all() - Probe all available CPUs
   *
   * Return: 0 if OK, -ve on error
   */
  int cpu_probe_all(void);
c764f454a   Ye Li   MLK-21828-1 uclas...
142
143
144
145
146
147
  /**
   * cpu_get_current_dev() - Get CPU udevice for current CPU
   *
   * Return: udevice if OK, - NULL on error
   */
  struct udevice *cpu_get_current_dev(void);
11f4dc158   Simon Glass   dm: Implement a C...
148
  #endif