2014-06-17 14:51:47 +00:00
|
|
|
__kpatch_funcs = ADDR(.kpatch.funcs);
|
|
|
|
__kpatch_funcs_end = ADDR(.kpatch.funcs) + SIZEOF(.kpatch.funcs);
|
2014-05-14 20:59:05 +00:00
|
|
|
__kpatch_dynrelas = ADDR(.kpatch.dynrelas);
|
|
|
|
__kpatch_dynrelas_end = ADDR(.kpatch.dynrelas) + SIZEOF(.kpatch.dynrelas);
|
2014-09-04 14:38:17 +00:00
|
|
|
__kpatch_checksum = ADDR(.kpatch.checksum);
|
2014-06-27 17:01:39 +00:00
|
|
|
SECTIONS
|
|
|
|
{
|
|
|
|
.kpatch.hooks.load : {
|
|
|
|
__kpatch_hooks_load = . ;
|
|
|
|
*(.kpatch.hooks.load)
|
|
|
|
__kpatch_hooks_load_end = . ;
|
2014-07-01 17:22:16 +00:00
|
|
|
/*
|
|
|
|
* Pad the end of the section with zeros in case the section is empty.
|
|
|
|
* This prevents the kernel from discarding the section at module
|
|
|
|
* load time. __kpatch_hooks_load_end will still point to the end of
|
|
|
|
* the section before the padding. If the .kpatch.hooks.load section
|
|
|
|
* is empty, __kpatch_hooks_load equals __kpatch_hooks_load_end.
|
|
|
|
*/
|
2014-06-27 17:01:39 +00:00
|
|
|
QUAD(0);
|
|
|
|
}
|
|
|
|
.kpatch.hooks.unload : {
|
|
|
|
__kpatch_hooks_unload = . ;
|
|
|
|
*(.kpatch.hooks.unload)
|
|
|
|
__kpatch_hooks_unload_end = . ;
|
|
|
|
QUAD(0);
|
|
|
|
}
|
2014-07-02 17:35:18 +00:00
|
|
|
.kpatch.force : {
|
|
|
|
__kpatch_force_funcs = . ;
|
|
|
|
*(.kpatch.force)
|
|
|
|
__kpatch_force_funcs_end = . ;
|
|
|
|
QUAD(0);
|
|
|
|
}
|
2014-06-27 17:01:39 +00:00
|
|
|
}
|