PM / devfreq: Reorder fields in 'struct devfreq_dev_status'
authorChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Mon, 8 May 2023 07:42:15 +0000 (09:42 +0200)
committerChanwoo Choi <cw00.choi@samsung.com>
Mon, 29 May 2023 14:23:04 +0000 (23:23 +0900)
Group some variables based on their sizes to reduce holes.
On x86_64, this shrinks the size of 'struct devfreq_dev_status' from 72 to
64 bytes.

This structure is used both to allocate static variables or is embedded in
some other structures. In both cases, reducing its size is nice to have.

Moreover, the whole structure now fits in a single cache line on x86_64.

Finally, it makes the order of code match the order of the above kernel
doc.

Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Acked-by: MyungJoo Ham <myungjoo.ham@samsung.com>
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
include/linux/devfreq.h

index 7fd704bb8f3de88c9720ced342cceae31944a27d..d312ffbac4dd55733203d6763b15ada90b91b872 100644 (file)
@@ -108,7 +108,6 @@ struct devfreq_dev_profile {
        unsigned long initial_freq;
        unsigned int polling_ms;
        enum devfreq_timer timer;
-       bool is_cooling_device;
 
        int (*target)(struct device *dev, unsigned long *freq, u32 flags);
        int (*get_dev_status)(struct device *dev,
@@ -118,6 +117,8 @@ struct devfreq_dev_profile {
 
        unsigned long *freq_table;
        unsigned int max_state;
+
+       bool is_cooling_device;
 };
 
 /**