Он недокументирован, но выглядит как одна из оптимизаций в .NET 4.5. По-видимому, он используется для заполнения информационного кэша типа отражения, что ускоряет выполнение последующего кода отражения на общих типах платформы. Об этом есть комментарий в справочном источнике для System.Reflection.Assembly.cs, свойство RuntimeAssembly.Flags:
// Each blessed API will be annotated with a "__DynamicallyInvokableAttribute".
// This "__DynamicallyInvokableAttribute" is a type defined in its own assembly.
// So the ctor is always a MethodDef and the type a TypeDef.
// We cache this ctor MethodDef token for faster custom attribute lookup.
// If this attribute type doesn't exist in the assembly, it means the assembly
// doesn't contain any blessed APIs.
Type invocableAttribute = GetType("__DynamicallyInvokableAttribute", false);
if (invocableAttribute != null)
{
Contract.Assert(((MetadataToken)invocableAttribute.MetadataToken).IsTypeDef);
ConstructorInfo ctor = invocableAttribute.GetConstructor(Type.EmptyTypes);
Contract.Assert(ctor != null);
int token = ctor.MetadataToken;
Contract.Assert(((MetadataToken)token).IsMethodDef);
flags |= (ASSEMBLY_FLAGS)token & ASSEMBLY_FLAGS.ASSEMBLY_FLAGS_TOKEN_MASK;
}
Без дальнейших намеков, что может означать «благословенный API». Хотя из контекста ясно, что это будет работать только с типами в самой структуре. Где-то должен быть дополнительный код, который проверяет атрибут, примененный к типам и методам. Не знаю, где это находится, но, учитывая, что для кэширования необходимо иметь представление обо всех типах .NET, я могу думать только о Ngen.exe.