Blame view

include/cpu.h 3.08 KB
11f4dc158   Simon Glass   dm: Implement a C...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
  /*
   * Copyright (c) 2015 Google, Inc
   * Written by Simon Glass <sjg@chromium.org>
   *
   * SPDX-License-Identifier:	GPL-2.0+
   */
  
  #ifndef __CPU_H
  #define __CPU_H
  
  /**
   * struct cpu_platdata - platform data for a CPU
   *
   * This can be accessed with dev_get_parent_platdata() for any UCLASS_CPU
   * device.
   *
   * @cpu_id:	Platform-specific way of identifying the CPU.
740d5d34b   Simon Glass   cpu: Add support ...
18
   * @ucode_version: Microcode version, if CPU_FEAT_UCODE is set
11f4dc158   Simon Glass   dm: Implement a C...
19
20
21
   */
  struct cpu_platdata {
  	int cpu_id;
740d5d34b   Simon Glass   cpu: Add support ...
22
23
  	int ucode_version;
  	ulong device_id;
6f192ddcb   Alexander Graf   cpu: Add DMTF id ...
24
25
  	u16 family;		/* DMTF CPU Family */
  	u32 id[2];		/* DMTF CPU Processor IDs */
11f4dc158   Simon Glass   dm: Implement a C...
26
27
28
29
30
31
  };
  
  /* 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 ...
32
33
  	CPU_FEAT_UCODE		= 2,	/* Requires/uses microcode */
  	CPU_FEAT_DEVICE_ID	= 3,	/* Provides a device ID */
11f4dc158   Simon Glass   dm: Implement a C...
34
35
36
37
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
  
  	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...
68
69
70
71
72
73
74
75
  
  	/**
  	 * 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...
76
77
78
79
80
81
82
83
84
85
  
  	/**
  	 * 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);
11f4dc158   Simon Glass   dm: Implement a C...
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
  };
  
  #define cpu_get_ops(dev)        ((struct cpu_ops *)(dev)->driver->ops)
  
  /**
   * cpu_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 cpu_get_desc(struct udevice *dev, char *buf, int size);
  
  /**
   * cpu_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 cpu_get_info(struct udevice *dev, struct cpu_info *info);
780bfdd3c   Bin Meng   dm: cpu: Add a ne...
108
109
110
111
112
113
114
  /**
   * cpu_get_count() - Get number of CPUs
   *
   * @dev:	Device to check (UCLASS_CPU)
   * @return CPU count if OK, -ve on error
   */
  int cpu_get_count(struct udevice *dev);
94eaa79ce   Alexander Graf   cpu: Add get_vend...
115
116
117
118
119
120
121
122
123
  /**
   * cpu_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 cpu_get_vendor(struct udevice *dev, char *buf, int size);
11f4dc158   Simon Glass   dm: Implement a C...
124
  #endif