<feed xmlns='http://www.w3.org/2005/Atom'>
<title>linux-stable.git/drivers/edac/edac_module.c, branch v3.7</title>
<subtitle>Linux kernel stable tree</subtitle>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/'/>
<entry>
<title>edac: create top-level debugfs directory</title>
<updated>2012-06-12T15:15:49+00:00</updated>
<author>
<name>Rob Herring</name>
<email>rob.herring@calxeda.com</email>
</author>
<published>2012-06-12T02:32:12+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=e7930ba49e469d9ce7374a788336caf955f8d7e2'/>
<id>e7930ba49e469d9ce7374a788336caf955f8d7e2</id>
<content type='text'>
Create a single, top-level "edac" directory for debugfs. An "mc[0-N]"
directory is then created for each memory controller. Individual drivers
can create additional entries such as h/w error injection control.

Signed-off-by: Rob Herring &lt;rob.herring@calxeda.com&gt;
Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Create a single, top-level "edac" directory for debugfs. An "mc[0-N]"
directory is then created for each memory controller. Individual drivers
can create additional entries such as h/w error injection control.

Signed-off-by: Rob Herring &lt;rob.herring@calxeda.com&gt;
Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>edac: Increase version to 3.0.0</title>
<updated>2012-06-11T16:23:50+00:00</updated>
<author>
<name>Mauro Carvalho Chehab</name>
<email>mchehab@redhat.com</email>
</author>
<published>2012-05-10T15:43:01+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=5156a5f4e058b906c1e8c0fe2ab16f30b60dee96'/>
<id>5156a5f4e058b906c1e8c0fe2ab16f30b60dee96</id>
<content type='text'>
There were lots of changes introduced to justify renaming it to
3.0.0:

  - EDAC core were redesigned to represent all types of
    memory controllers;

  - EDAC API were redesigned to properly represent the memory
    controller hierarchy;

  - a tracepoint-based API were added to report memory errors.

Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
There were lots of changes introduced to justify renaming it to
3.0.0:

  - EDAC core were redesigned to represent all types of
    memory controllers;

  - EDAC API were redesigned to properly represent the memory
    controller hierarchy;

  - a tracepoint-based API were added to report memory errors.

Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>edac: Convert debugfX to edac_dbg(X,</title>
<updated>2012-06-11T16:23:49+00:00</updated>
<author>
<name>Joe Perches</name>
<email>joe@perches.com</email>
</author>
<published>2012-04-29T20:08:39+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=956b9ba156dbfdb9cede2b2927ddf8be2233b3a7'/>
<id>956b9ba156dbfdb9cede2b2927ddf8be2233b3a7</id>
<content type='text'>
Use a more common debugging style.

Remove __FILE__ uses, add missing newlines,
coalesce formats and align arguments.

Signed-off-by: Joe Perches &lt;joe@perches.com&gt;
Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Use a more common debugging style.

Remove __FILE__ uses, add missing newlines,
coalesce formats and align arguments.

Signed-off-by: Joe Perches &lt;joe@perches.com&gt;
Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>edac: Don't add __func__ or __FILE__ for debugf[0-9] msgs</title>
<updated>2012-06-11T16:23:47+00:00</updated>
<author>
<name>Mauro Carvalho Chehab</name>
<email>mchehab@redhat.com</email>
</author>
<published>2012-04-29T14:59:14+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=dd23cd6eb1f59ba722a6e6aa228adff7c01404de'/>
<id>dd23cd6eb1f59ba722a6e6aa228adff7c01404de</id>
<content type='text'>
The debug macro already adds that. Most of the work here was
made by this small script:

$f .=$_ while (&lt;&gt;);

$f =~ s/(debugf[0-9]\s*\(\s*)__FILE__\s*": /\1"/g;
$f =~ s/(debugf[0-9]\s*\(\s*)__FILE__\s*/\1/g;
$f =~ s/(debugf[0-9]\s*\(\s*)__FILE__\s*"MC: /\1"/g;

$f =~ s/(debugf[0-9]\s*\(\")\%s[\:\,\(\)]*\s*([^\"]*\s*[^\)]+)__func__\s*\,\s*/\1\2/g;
$f =~ s/(debugf[0-9]\s*\(\")\%s[\:\,\(\)]*\s*([^\"]*\s*[^\)]+),\s*__func__\s*\)/\1\2)/g;
$f =~ s/(debugf[0-9]\s*\(\"MC\:\s*)\%s[\:\,\(\)]*\s*([^\"]*\s*[^\)]+)__func__\s*\,\s*/\1\2/g;
$f =~ s/(debugf[0-9]\s*\(\"MC\:\s*)\%s[\:\,\(\)]*\s*([^\"]*\s*[^\)]+),\s*__func__\s*\)/\1\2)/g;

$f =~ s/\"MC\: \\n\"/"MC:\\n"/g;

print $f;

After running the script, manual cleanups were done to fix it the remaining
places.

While here, removed the __LINE__ on most places, as it doesn't actually give
useful info on most places.

Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
The debug macro already adds that. Most of the work here was
made by this small script:

$f .=$_ while (&lt;&gt;);

$f =~ s/(debugf[0-9]\s*\(\s*)__FILE__\s*": /\1"/g;
$f =~ s/(debugf[0-9]\s*\(\s*)__FILE__\s*/\1/g;
$f =~ s/(debugf[0-9]\s*\(\s*)__FILE__\s*"MC: /\1"/g;

$f =~ s/(debugf[0-9]\s*\(\")\%s[\:\,\(\)]*\s*([^\"]*\s*[^\)]+)__func__\s*\,\s*/\1\2/g;
$f =~ s/(debugf[0-9]\s*\(\")\%s[\:\,\(\)]*\s*([^\"]*\s*[^\)]+),\s*__func__\s*\)/\1\2)/g;
$f =~ s/(debugf[0-9]\s*\(\"MC\:\s*)\%s[\:\,\(\)]*\s*([^\"]*\s*[^\)]+)__func__\s*\,\s*/\1\2/g;
$f =~ s/(debugf[0-9]\s*\(\"MC\:\s*)\%s[\:\,\(\)]*\s*([^\"]*\s*[^\)]+),\s*__func__\s*\)/\1\2)/g;

$f =~ s/\"MC\: \\n\"/"MC:\\n"/g;

print $f;

After running the script, manual cleanups were done to fix it the remaining
places.

While here, removed the __LINE__ on most places, as it doesn't actually give
useful info on most places.

Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>edac: rewrite the sysfs code to use struct device</title>
<updated>2012-06-11T16:23:30+00:00</updated>
<author>
<name>Mauro Carvalho Chehab</name>
<email>mchehab@redhat.com</email>
</author>
<published>2012-04-16T19:41:11+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=7a623c039075e4ea21648d88133fafa6dcfd113d'/>
<id>7a623c039075e4ea21648d88133fafa6dcfd113d</id>
<content type='text'>
The EDAC subsystem uses the old struct sysdev approach,
creating all nodes using the raw sysfs API. This is bad,
as the API is deprecated.

As we'll be changing the EDAC API, let's first port the existing
code to struct device.

There's one drawback on this patch: driver-specific sysfs
nodes, used by mpc85xx_edac, amd64_edac and i7core_edac
 won't be created anymore. While it would be possible to
also port the device-specific code, that would mix kobj with
struct device, with is not recommended. Also, it is easier and nicer
to move the code to the drivers, instead, as the core can get rid
of some complex logic that just emulates what the device_add()
and device_create_file() already does.

The next patches will convert the driver-specific code to use
the device-specific calls. Then, the remaining bits of the old
sysfs API will be removed.

NOTE: a per-MC bus is required, otherwise devices with more than
one memory controller will hit a bug like the one below:

[  819.094946] EDAC DEBUG: find_mci_by_dev: find_mci_by_dev()
[  819.094948] EDAC DEBUG: edac_create_sysfs_mci_device: edac_create_sysfs_mci_device() idx=1
[  819.094952] EDAC DEBUG: edac_create_sysfs_mci_device: edac_create_sysfs_mci_device(): creating device mc1
[  819.094967] EDAC DEBUG: edac_create_sysfs_mci_device: edac_create_sysfs_mci_device creating dimm0, located at channel 0 slot 0
[  819.094984] ------------[ cut here ]------------
[  819.100142] WARNING: at fs/sysfs/dir.c:481 sysfs_add_one+0xc1/0xf0()
[  819.107282] Hardware name: S2600CP
[  819.111078] sysfs: cannot create duplicate filename '/bus/edac/devices/dimm0'
[  819.119062] Modules linked in: sb_edac(+) edac_core ip6table_filter ip6_tables ebtable_nat ebtables ipt_MASQUERADE iptable_nat nf_nat nf_conntrack_ipv4 nf_defrag_ipv4 xt_state nf_conntrack ipt_REJECT xt_CHECKSUM iptable_mangle iptable_filter ip_tables bridge stp llc sunrpc binfmt_misc dm_mirror dm_region_hash dm_log vhost_net macvtap macvlan tun kvm microcode pcspkr iTCO_wdt iTCO_vendor_support igb i2c_i801 i2c_core sg ioatdma dca sr_mod cdrom sd_mod crc_t10dif ahci libahci isci libsas libata scsi_transport_sas scsi_mod wmi dm_mod [last unloaded: scsi_wait_scan]
[  819.175748] Pid: 10902, comm: modprobe Not tainted 3.3.0-0.11.el7.v12.2.x86_64 #1
[  819.184113] Call Trace:
[  819.186868]  [&lt;ffffffff8105adaf&gt;] warn_slowpath_common+0x7f/0xc0
[  819.193573]  [&lt;ffffffff8105aea6&gt;] warn_slowpath_fmt+0x46/0x50
[  819.200000]  [&lt;ffffffff811f53d1&gt;] sysfs_add_one+0xc1/0xf0
[  819.206025]  [&lt;ffffffff811f5cf5&gt;] sysfs_do_create_link+0x135/0x220
[  819.212944]  [&lt;ffffffff811f7023&gt;] ? sysfs_create_group+0x13/0x20
[  819.219656]  [&lt;ffffffff811f5df3&gt;] sysfs_create_link+0x13/0x20
[  819.226109]  [&lt;ffffffff813b04f6&gt;] bus_add_device+0xe6/0x1b0
[  819.232350]  [&lt;ffffffff813ae7cb&gt;] device_add+0x2db/0x460
[  819.238300]  [&lt;ffffffffa0325634&gt;] edac_create_dimm_object+0x84/0xf0 [edac_core]
[  819.246460]  [&lt;ffffffffa0325e18&gt;] edac_create_sysfs_mci_device+0xe8/0x290 [edac_core]
[  819.255215]  [&lt;ffffffffa0322e2a&gt;] edac_mc_add_mc+0x5a/0x2c0 [edac_core]
[  819.262611]  [&lt;ffffffffa03412df&gt;] sbridge_register_mci+0x1bc/0x279 [sb_edac]
[  819.270493]  [&lt;ffffffffa03417a3&gt;] sbridge_probe+0xef/0x175 [sb_edac]
[  819.277630]  [&lt;ffffffff813ba4e8&gt;] ? pm_runtime_enable+0x58/0x90
[  819.284268]  [&lt;ffffffff812f430c&gt;] local_pci_probe+0x5c/0xd0
[  819.290508]  [&lt;ffffffff812f5ba1&gt;] __pci_device_probe+0xf1/0x100
[  819.297117]  [&lt;ffffffff812f5bea&gt;] pci_device_probe+0x3a/0x60
[  819.303457]  [&lt;ffffffff813b1003&gt;] really_probe+0x73/0x270
[  819.309496]  [&lt;ffffffff813b138e&gt;] driver_probe_device+0x4e/0xb0
[  819.316104]  [&lt;ffffffff813b149b&gt;] __driver_attach+0xab/0xb0
[  819.322337]  [&lt;ffffffff813b13f0&gt;] ? driver_probe_device+0xb0/0xb0
[  819.329151]  [&lt;ffffffff813af5d6&gt;] bus_for_each_dev+0x56/0x90
[  819.335489]  [&lt;ffffffff813b0d7e&gt;] driver_attach+0x1e/0x20
[  819.341534]  [&lt;ffffffff813b0980&gt;] bus_add_driver+0x1b0/0x2a0
[  819.347884]  [&lt;ffffffffa0347000&gt;] ? 0xffffffffa0346fff
[  819.353641]  [&lt;ffffffff813b19f6&gt;] driver_register+0x76/0x140
[  819.359980]  [&lt;ffffffff8159f18b&gt;] ? printk+0x51/0x53
[  819.365524]  [&lt;ffffffffa0347000&gt;] ? 0xffffffffa0346fff
[  819.371291]  [&lt;ffffffff812f5896&gt;] __pci_register_driver+0x56/0xd0
[  819.378096]  [&lt;ffffffffa0347054&gt;] sbridge_init+0x54/0x1000 [sb_edac]
[  819.385231]  [&lt;ffffffff8100203f&gt;] do_one_initcall+0x3f/0x170
[  819.391577]  [&lt;ffffffff810bcd2e&gt;] sys_init_module+0xbe/0x230
[  819.397926]  [&lt;ffffffff815bb529&gt;] system_call_fastpath+0x16/0x1b
[  819.404633] ---[ end trace 1654fdd39556689f ]---

This happens because the bus is not being properly initialized.
Instead of putting the memory sub-devices inside the memory controller,
it is putting everything under the same directory:

$ tree /sys/bus/edac/
/sys/bus/edac/
├── devices
│   ├── all_channel_counts -&gt; ../../../devices/system/edac/mc/mc0/all_channel_counts
│   ├── csrow0 -&gt; ../../../devices/system/edac/mc/mc0/csrow0
│   ├── csrow1 -&gt; ../../../devices/system/edac/mc/mc0/csrow1
│   ├── csrow2 -&gt; ../../../devices/system/edac/mc/mc0/csrow2
│   ├── dimm0 -&gt; ../../../devices/system/edac/mc/mc0/dimm0
│   ├── dimm1 -&gt; ../../../devices/system/edac/mc/mc0/dimm1
│   ├── dimm3 -&gt; ../../../devices/system/edac/mc/mc0/dimm3
│   ├── dimm6 -&gt; ../../../devices/system/edac/mc/mc0/dimm6
│   ├── inject_addrmatch -&gt; ../../../devices/system/edac/mc/mc0/inject_addrmatch
│   ├── mc -&gt; ../../../devices/system/edac/mc
│   └── mc0 -&gt; ../../../devices/system/edac/mc/mc0
├── drivers
├── drivers_autoprobe
├── drivers_probe
└── uevent

On a multi-memory controller system, the names "csrow%d" and "dimm%d"
should be under "mc%d", and not at the main hierarchy level.

So, we need to create a per-MC bus, in order to have its own namespace.

Reviewed-by: Aristeu Rozanski &lt;arozansk@redhat.com&gt;
Cc: Doug Thompson &lt;norsk5@yahoo.com&gt;
Cc: Greg K H &lt;gregkh@linuxfoundation.org&gt;
Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
The EDAC subsystem uses the old struct sysdev approach,
creating all nodes using the raw sysfs API. This is bad,
as the API is deprecated.

As we'll be changing the EDAC API, let's first port the existing
code to struct device.

There's one drawback on this patch: driver-specific sysfs
nodes, used by mpc85xx_edac, amd64_edac and i7core_edac
 won't be created anymore. While it would be possible to
also port the device-specific code, that would mix kobj with
struct device, with is not recommended. Also, it is easier and nicer
to move the code to the drivers, instead, as the core can get rid
of some complex logic that just emulates what the device_add()
and device_create_file() already does.

The next patches will convert the driver-specific code to use
the device-specific calls. Then, the remaining bits of the old
sysfs API will be removed.

NOTE: a per-MC bus is required, otherwise devices with more than
one memory controller will hit a bug like the one below:

[  819.094946] EDAC DEBUG: find_mci_by_dev: find_mci_by_dev()
[  819.094948] EDAC DEBUG: edac_create_sysfs_mci_device: edac_create_sysfs_mci_device() idx=1
[  819.094952] EDAC DEBUG: edac_create_sysfs_mci_device: edac_create_sysfs_mci_device(): creating device mc1
[  819.094967] EDAC DEBUG: edac_create_sysfs_mci_device: edac_create_sysfs_mci_device creating dimm0, located at channel 0 slot 0
[  819.094984] ------------[ cut here ]------------
[  819.100142] WARNING: at fs/sysfs/dir.c:481 sysfs_add_one+0xc1/0xf0()
[  819.107282] Hardware name: S2600CP
[  819.111078] sysfs: cannot create duplicate filename '/bus/edac/devices/dimm0'
[  819.119062] Modules linked in: sb_edac(+) edac_core ip6table_filter ip6_tables ebtable_nat ebtables ipt_MASQUERADE iptable_nat nf_nat nf_conntrack_ipv4 nf_defrag_ipv4 xt_state nf_conntrack ipt_REJECT xt_CHECKSUM iptable_mangle iptable_filter ip_tables bridge stp llc sunrpc binfmt_misc dm_mirror dm_region_hash dm_log vhost_net macvtap macvlan tun kvm microcode pcspkr iTCO_wdt iTCO_vendor_support igb i2c_i801 i2c_core sg ioatdma dca sr_mod cdrom sd_mod crc_t10dif ahci libahci isci libsas libata scsi_transport_sas scsi_mod wmi dm_mod [last unloaded: scsi_wait_scan]
[  819.175748] Pid: 10902, comm: modprobe Not tainted 3.3.0-0.11.el7.v12.2.x86_64 #1
[  819.184113] Call Trace:
[  819.186868]  [&lt;ffffffff8105adaf&gt;] warn_slowpath_common+0x7f/0xc0
[  819.193573]  [&lt;ffffffff8105aea6&gt;] warn_slowpath_fmt+0x46/0x50
[  819.200000]  [&lt;ffffffff811f53d1&gt;] sysfs_add_one+0xc1/0xf0
[  819.206025]  [&lt;ffffffff811f5cf5&gt;] sysfs_do_create_link+0x135/0x220
[  819.212944]  [&lt;ffffffff811f7023&gt;] ? sysfs_create_group+0x13/0x20
[  819.219656]  [&lt;ffffffff811f5df3&gt;] sysfs_create_link+0x13/0x20
[  819.226109]  [&lt;ffffffff813b04f6&gt;] bus_add_device+0xe6/0x1b0
[  819.232350]  [&lt;ffffffff813ae7cb&gt;] device_add+0x2db/0x460
[  819.238300]  [&lt;ffffffffa0325634&gt;] edac_create_dimm_object+0x84/0xf0 [edac_core]
[  819.246460]  [&lt;ffffffffa0325e18&gt;] edac_create_sysfs_mci_device+0xe8/0x290 [edac_core]
[  819.255215]  [&lt;ffffffffa0322e2a&gt;] edac_mc_add_mc+0x5a/0x2c0 [edac_core]
[  819.262611]  [&lt;ffffffffa03412df&gt;] sbridge_register_mci+0x1bc/0x279 [sb_edac]
[  819.270493]  [&lt;ffffffffa03417a3&gt;] sbridge_probe+0xef/0x175 [sb_edac]
[  819.277630]  [&lt;ffffffff813ba4e8&gt;] ? pm_runtime_enable+0x58/0x90
[  819.284268]  [&lt;ffffffff812f430c&gt;] local_pci_probe+0x5c/0xd0
[  819.290508]  [&lt;ffffffff812f5ba1&gt;] __pci_device_probe+0xf1/0x100
[  819.297117]  [&lt;ffffffff812f5bea&gt;] pci_device_probe+0x3a/0x60
[  819.303457]  [&lt;ffffffff813b1003&gt;] really_probe+0x73/0x270
[  819.309496]  [&lt;ffffffff813b138e&gt;] driver_probe_device+0x4e/0xb0
[  819.316104]  [&lt;ffffffff813b149b&gt;] __driver_attach+0xab/0xb0
[  819.322337]  [&lt;ffffffff813b13f0&gt;] ? driver_probe_device+0xb0/0xb0
[  819.329151]  [&lt;ffffffff813af5d6&gt;] bus_for_each_dev+0x56/0x90
[  819.335489]  [&lt;ffffffff813b0d7e&gt;] driver_attach+0x1e/0x20
[  819.341534]  [&lt;ffffffff813b0980&gt;] bus_add_driver+0x1b0/0x2a0
[  819.347884]  [&lt;ffffffffa0347000&gt;] ? 0xffffffffa0346fff
[  819.353641]  [&lt;ffffffff813b19f6&gt;] driver_register+0x76/0x140
[  819.359980]  [&lt;ffffffff8159f18b&gt;] ? printk+0x51/0x53
[  819.365524]  [&lt;ffffffffa0347000&gt;] ? 0xffffffffa0346fff
[  819.371291]  [&lt;ffffffff812f5896&gt;] __pci_register_driver+0x56/0xd0
[  819.378096]  [&lt;ffffffffa0347054&gt;] sbridge_init+0x54/0x1000 [sb_edac]
[  819.385231]  [&lt;ffffffff8100203f&gt;] do_one_initcall+0x3f/0x170
[  819.391577]  [&lt;ffffffff810bcd2e&gt;] sys_init_module+0xbe/0x230
[  819.397926]  [&lt;ffffffff815bb529&gt;] system_call_fastpath+0x16/0x1b
[  819.404633] ---[ end trace 1654fdd39556689f ]---

This happens because the bus is not being properly initialized.
Instead of putting the memory sub-devices inside the memory controller,
it is putting everything under the same directory:

$ tree /sys/bus/edac/
/sys/bus/edac/
├── devices
│   ├── all_channel_counts -&gt; ../../../devices/system/edac/mc/mc0/all_channel_counts
│   ├── csrow0 -&gt; ../../../devices/system/edac/mc/mc0/csrow0
│   ├── csrow1 -&gt; ../../../devices/system/edac/mc/mc0/csrow1
│   ├── csrow2 -&gt; ../../../devices/system/edac/mc/mc0/csrow2
│   ├── dimm0 -&gt; ../../../devices/system/edac/mc/mc0/dimm0
│   ├── dimm1 -&gt; ../../../devices/system/edac/mc/mc0/dimm1
│   ├── dimm3 -&gt; ../../../devices/system/edac/mc/mc0/dimm3
│   ├── dimm6 -&gt; ../../../devices/system/edac/mc/mc0/dimm6
│   ├── inject_addrmatch -&gt; ../../../devices/system/edac/mc/mc0/inject_addrmatch
│   ├── mc -&gt; ../../../devices/system/edac/mc
│   └── mc0 -&gt; ../../../devices/system/edac/mc/mc0
├── drivers
├── drivers_autoprobe
├── drivers_probe
└── uevent

On a multi-memory controller system, the names "csrow%d" and "dimm%d"
should be under "mc%d", and not at the main hierarchy level.

So, we need to create a per-MC bus, in order to have its own namespace.

Reviewed-by: Aristeu Rozanski &lt;arozansk@redhat.com&gt;
Cc: Doug Thompson &lt;norsk5@yahoo.com&gt;
Cc: Greg K H &lt;gregkh@linuxfoundation.org&gt;
Signed-off-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>edac: Drop __DATE__ usage</title>
<updated>2011-04-18T22:23:22+00:00</updated>
<author>
<name>Michal Marek</name>
<email>mmarek@suse.cz</email>
</author>
<published>2011-04-01T10:41:20+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=152ba3942276c2a240703669ae4a3099e0a79451'/>
<id>152ba3942276c2a240703669ae4a3099e0a79451</id>
<content type='text'>
The kernel already prints its build timestamp during boot, no need to
repeat it in random drivers and produce different object files each
time.

Cc: Doug Thompson &lt;dougthompson@xmission.com&gt;
Cc: bluesmoke-devel@lists.sourceforge.net
Cc: linux-edac@vger.kernel.org
Acked-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
Signed-off-by: Michal Marek &lt;mmarek@suse.cz&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
The kernel already prints its build timestamp during boot, no need to
repeat it in random drivers and produce different object files each
time.

Cc: Doug Thompson &lt;dougthompson@xmission.com&gt;
Cc: bluesmoke-devel@lists.sourceforge.net
Cc: linux-edac@vger.kernel.org
Acked-by: Mauro Carvalho Chehab &lt;mchehab@redhat.com&gt;
Signed-off-by: Michal Marek &lt;mmarek@suse.cz&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>EDAC: Export edac sysfs class to users.</title>
<updated>2010-10-21T12:47:59+00:00</updated>
<author>
<name>Borislav Petkov</name>
<email>borislav.petkov@amd.com</email>
</author>
<published>2010-09-02T15:26:48+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=30e1f7a8122145f44f45c95366e27b6bb0b08428'/>
<id>30e1f7a8122145f44f45c95366e27b6bb0b08428</id>
<content type='text'>
Move toplevel sysfs class to the stub and make it available to
non-modularized code too. Add proper refcounting of its users and move
the registration functionality into the reference counting routines.

Signed-off-by: Borislav Petkov &lt;borislav.petkov@amd.com&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Move toplevel sysfs class to the stub and make it available to
non-modularized code too. Add proper refcounting of its users and move
the registration functionality into the reference counting routines.

Signed-off-by: Borislav Petkov &lt;borislav.petkov@amd.com&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>Driver core: change sysdev classes to use dynamic kobject names</title>
<updated>2008-01-25T04:40:40+00:00</updated>
<author>
<name>Kay Sievers</name>
<email>kay.sievers@vrfy.org</email>
</author>
<published>2007-12-20T01:09:39+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=af5ca3f4ec5cc4432a42a73b050dd8898ce8fd00'/>
<id>af5ca3f4ec5cc4432a42a73b050dd8898ce8fd00</id>
<content type='text'>
All kobjects require a dynamically allocated name now. We no longer
need to keep track if the name is statically assigned, we can just
unconditionally free() all kobject names on cleanup.

Signed-off-by: Kay Sievers &lt;kay.sievers@vrfy.org&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
All kobjects require a dynamically allocated name now. We no longer
need to keep track if the name is statically assigned, we can just
unconditionally free() all kobject names on cleanup.

Signed-off-by: Kay Sievers &lt;kay.sievers@vrfy.org&gt;
Signed-off-by: Greg Kroah-Hartman &lt;gregkh@suse.de&gt;

</pre>
</div>
</content>
</entry>
<entry>
<title>drivers/edac: code tidying on export-gpl</title>
<updated>2007-07-19T17:04:57+00:00</updated>
<author>
<name>Doug Thompson</name>
<email>dougthompson@xmission.com</email>
</author>
<published>2007-07-19T08:50:30+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=fb3fb2068775a1363265edc00870aa5e2f0e3631'/>
<id>fb3fb2068775a1363265edc00870aa5e2f0e3631</id>
<content type='text'>
Change EXPORT_SYMBOLs to EXPORT_SYMBOLS_GPL
Tidy changes: blank lines, inline removal, add comment

Signed-off-by: Doug Thompson &lt;dougthompson@xmission.com&gt;
Cc: Greg KH &lt;greg@kroah.com&gt;
Cc: Alan Cox &lt;alan@lxorguk.ukuu.org.uk&gt;
Signed-off-by: Andrew Morton &lt;akpm@linux-foundation.org&gt;
Signed-off-by: Linus Torvalds &lt;torvalds@linux-foundation.org&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
Change EXPORT_SYMBOLs to EXPORT_SYMBOLS_GPL
Tidy changes: blank lines, inline removal, add comment

Signed-off-by: Doug Thompson &lt;dougthompson@xmission.com&gt;
Cc: Greg KH &lt;greg@kroah.com&gt;
Cc: Alan Cox &lt;alan@lxorguk.ukuu.org.uk&gt;
Signed-off-by: Andrew Morton &lt;akpm@linux-foundation.org&gt;
Signed-off-by: Linus Torvalds &lt;torvalds@linux-foundation.org&gt;
</pre>
</div>
</content>
</entry>
<entry>
<title>drivers/edac: fix edac_mc sysfs completion code</title>
<updated>2007-07-19T17:04:57+00:00</updated>
<author>
<name>Doug Thompson</name>
<email>dougthompson@xmission.com</email>
</author>
<published>2007-07-19T08:50:27+00:00</published>
<link rel='alternate' type='text/html' href='https://git.tavy.me/linux-stable.git/commit/?id=8096cfafbb7ad3cb1a286ae7e8086167f4ebb4b6'/>
<id>8096cfafbb7ad3cb1a286ae7e8086167f4ebb4b6</id>
<content type='text'>
This patch refactors the 'releasing' of kobjects for the edac_mc type of
device.  The correct pattern of kobject release is followed.

As internal kobjs are allocated they bump a ref count on the top level kobj.
It in turn has a module ref count on the edac_core module.  When internal
kobjects are released, they dec the ref count on the top level kobj.  When the
top level kobj reaches zero, it decrements the ref count on the edac_core
object, allow it to be unloaded, as all resources have all now been released.

Cc: Alan Cox alan@lxorguk.ukuu.org.uk
Signed-off-by: Doug Thompson &lt;dougthompson@xmission.com&gt;
Acked-by: Greg KH &lt;greg@kroah.com&gt;
Signed-off-by: Andrew Morton &lt;akpm@linux-foundation.org&gt;
Signed-off-by: Linus Torvalds &lt;torvalds@linux-foundation.org&gt;
</content>
<content type='xhtml'>
<div xmlns='http://www.w3.org/1999/xhtml'>
<pre>
This patch refactors the 'releasing' of kobjects for the edac_mc type of
device.  The correct pattern of kobject release is followed.

As internal kobjs are allocated they bump a ref count on the top level kobj.
It in turn has a module ref count on the edac_core module.  When internal
kobjects are released, they dec the ref count on the top level kobj.  When the
top level kobj reaches zero, it decrements the ref count on the edac_core
object, allow it to be unloaded, as all resources have all now been released.

Cc: Alan Cox alan@lxorguk.ukuu.org.uk
Signed-off-by: Doug Thompson &lt;dougthompson@xmission.com&gt;
Acked-by: Greg KH &lt;greg@kroah.com&gt;
Signed-off-by: Andrew Morton &lt;akpm@linux-foundation.org&gt;
Signed-off-by: Linus Torvalds &lt;torvalds@linux-foundation.org&gt;
</pre>
</div>
</content>
</entry>
</feed>
