Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
agent_status Enumeration
The valid states for an agent.
enum agent_status;
Values
| Name | Description | 
|---|---|
| agent_canceled | The agentwas canceled. | 
| agent_created | The agenthas been created but not started. | 
| agent_done | The agentfinished without being canceled. | 
| agent_runnable | The agenthas been started, but not entered itsrunmethod. | 
| agent_started | The agenthas started. | 
Remarks
For more information, see Asynchronous Agents.
Requirements
Header: concrt.h
Agents_EventType Enumeration
The types of events that can be traced using the tracing functionality offered by the Agents Library
enum Agents_EventType;
Values
| Name | Description | 
|---|---|
| AGENTS_EVENT_CREATE | An event type that represents the creation of an object | 
| AGENTS_EVENT_DESTROY | An event type that represents the deletion of an object | 
| AGENTS_EVENT_END | An event type that represents the conclusion of some processing | 
| AGENTS_EVENT_LINK | An event type that represents the linking of message blocks | 
| AGENTS_EVENT_NAME | An event type that represents the name for an object | 
| AGENTS_EVENT_SCHEDULE | An event type that represents the scheduling of a process | 
| AGENTS_EVENT_START | An event type that represents the initiation of some processing | 
| AGENTS_EVENT_UNLINK | An event type that represents the unlinking of message blocks | 
Requirements
Header: concrt.h
ConcRT_EventType Enumeration
The types of events that can be traced using the tracing functionality offered by the Concurrency Runtime.
enum ConcRT_EventType;
Values
| Name | Description | 
|---|---|
| CONCRT_EVENT_ATTACH | An event type that represents the act of a attaching to a scheduler. | 
| CONCRT_EVENT_BLOCK | An event type that represents the act of a context blocking. | 
| CONCRT_EVENT_DETACH | An event type that represents the act of a detaching from a scheduler. | 
| CONCRT_EVENT_END | An event type that marks the beginning of a start/end event pair. | 
| CONCRT_EVENT_GENERIC | An event type used for miscellaneous events. | 
| CONCRT_EVENT_IDLE | An event type that represents the act of a context becoming idle. | 
| CONCRT_EVENT_START | An event type that marks the beginning of a start/end event pair. | 
| CONCRT_EVENT_UNBLOCK | An event type that represents the act of unblocking a context. | 
| CONCRT_EVENT_YIELD | An event type that represents the act of a context yielding. | 
Requirements
Header: concrt.h Namespace: concurrency
Concrt_TraceFlags Enumeration
Trace flags for the event types
enum Concrt_TraceFlags;
Values
| Name | Description | 
|---|---|
| AgentEventFlag | |
| AllEventsFlag | |
| ContextEventFlag | |
| PPLEventFlag | |
| ResourceManagerEventFlag | |
| SchedulerEventFlag | |
| VirtualProcessorEventFlag | 
Requirements
Header: concrt.h
CriticalRegionType Enumeration
The type of critical region a context is inside.
enum CriticalRegionType;
Values
| Name | Description | 
|---|---|
| InsideCriticalRegion | Indicates that the context is inside a critical region. When inside a critical region, asynchronous suspensions are hidden from the scheduler. Should such a suspension happen, the Resource Manager will wait for the thread to become runnable and simply resume it instead of invoking the scheduler again. Any locks taken inside such a region must be taken with extreme care. | 
| InsideHyperCriticalRegion | Indicates that the context is inside a hyper-critical region. When inside a hyper-critical region, both synchronous and asynchronous suspensions are hidden from the scheduler. Should such a suspension or blocking happen, the resource manager will wait for the thread to become runnable and simply resume it instead of invoking the scheduler again. Locks taken inside such a region must never be shared with code running outside such a region. Doing so will cause unpredictable deadlock. | 
| OutsideCriticalRegion | Indicates that the context is outside any critical region. | 
Requirements
Header: concrtrm.h
DynamicProgressFeedbackType Enumeration
Used by the DynamicProgressFeedback policy to describe whether resources for the scheduler will be rebalanced according to statistical information gathered from the scheduler or only based on virtual processors going in and out of the idle state through calls to the Activate and Deactivate methods on the IVirtualProcessorRoot interface. For more information on available scheduler policies, see PolicyElementKey.
enum DynamicProgressFeedbackType;
Values
| Name | Description | 
|---|---|
| ProgressFeedbackDisabled | The scheduler does not gather progress information. Rebalancing is done based solely on the subscription level of the underlying hardware thread. For more information on subscription levels, see IExecutionResource::CurrentSubscriptionLevel. This value is reserved for use by the runtime. | 
| ProgressFeedbackEnabled | The scheduler gathers progress information and passes it to the resource manager. The resource manager will utilize this statistical information to rebalance resources on behalf of the scheduler in addition to the subscription level of the underlying hardware thread. For more information on subscription levels, see IExecutionResource::CurrentSubscriptionLevel. | 
join_type Enumeration
The type of a join messaging block.
enum join_type;
Values
| Name | Description | 
|---|---|
| greedy | Greedy joinmessaging blocks immediately accept a message upon propagation. This is more efficient, but has the possibility for live-lock, depending on the network configuration. | 
| non_greedy | Non-greedy joinmessaging blocks postpone messages and try and consume them after all have arrived. These are guaranteed to work, but slower. | 
Requirements
Header: agents.h
message_status Enumeration
The valid responses for an offer of a message object to a block.
enum message_status;
Values
| Name | Description | 
|---|---|
| accepted | The target accepted the message. | 
| declined | The target did not accept the message. | 
| missed | The target tried to accept the message, but it was no longer available. | 
| postponed | The target postponed the message. | 
Requirements
Header: agents.h
PolicyElementKey Enumeration
Policy keys describing aspects of scheduler behavior. Each policy element is described by a key-value pair. For more information about scheduler policies and their impact on schedulers, see Task Scheduler.
enum PolicyElementKey;
Values
| Name | Description | 
|---|---|
| ContextPriority | The operating system thread priority of each context in the scheduler. If this key is set to the value INHERIT_THREAD_PRIORITYthe contexts in the scheduler will inherit the priority of the thread that created the scheduler.Valid values : Any of the valid values for the Windows SetThreadPriorityfunction and the special valueINHERIT_THREAD_PRIORITYDefault value : THREAD_PRIORITY_NORMAL | 
| ContextStackSize | The reserved stack size of each context in the scheduler in kilobytes. Valid values : Positive integers Default value : 0, indicating that the process' default value for stack size be used. | 
| DynamicProgressFeedback | Determines whether the resources for the scheduler will be rebalanced according to statistical information gathered from the scheduler or only based on the subscription level of underlying hardware threads. For more information, see DynamicProgressFeedbackType. Valid values : A member of the DynamicProgressFeedbackTypeenumeration, eitherProgressFeedbackEnabledorProgressFeedbackDisabledDefault value : ProgressFeedbackEnabled | 
| LocalContextCacheSize | When the SchedulingProtocolpolicy key is set to the valueEnhanceScheduleGroupLocality, this specifies the maximum number of runnable contexts allowed to be cached in per virtual processor local queues. Such contexts will typically run in last-in-first-out (LIFO) order on the virtual processor that caused them to become runnable. Note that this policy key has no meaning when theSchedulingProtocolkey is set to the valueEnhanceForwardProgress.Valid values : Non-negative integers Default value : 8 | 
| MaxConcurrency | The maximum concurrency level desired by the scheduler. The resource manager will try to initially allocate this many virtual processors. The special value MaxExecutionResources indicates that the desired concurrency level is same as the number of hardware threads on the machine. If the value specified for MinConcurrencyis greater than the number of hardware threads on the machine andMaxConcurrencyis specified asMaxExecutionResources, the value forMaxConcurrencyis raised to match what is set forMinConcurrency.Valid values : Positive integers and the special value MaxExecutionResourcesDefault value : MaxExecutionResources | 
| MaxPolicyElementKey | The maximum policy element key. Not a valid element key. | 
| MinConcurrency | The minimum concurrency level that must be provided to the scheduler by the resource manager. The number of virtual processors assigned to a scheduler will never go below the minimum. The special value MaxExecutionResources indicates that the minimum concurrency level is same as the number of hardware threads on the machine. If the value specified for MaxConcurrencyis less than the number of hardware threads on the machine andMinConcurrencyis specified asMaxExecutionResources, the value forMinConcurrencyis lowered to match what is set forMaxConcurrency.Valid values : Non-negative integers and the special value MaxExecutionResources. Note that for scheduler policies used for the construction of Concurrency Runtime schedulers, the value0is invalid.Default value : 1 | 
| SchedulerKind | The type of threads that the scheduler will utilize for underlying execution contexts. For more information, see SchedulerType. Valid values : A member of the SchedulerTypeenumeration, for example,ThreadSchedulerDefault value : ThreadScheduler. This translates to Win32 threads on all operating systems. | 
| SchedulingProtocol | Describes which scheduling algorithm will be used by the scheduler. For more information, see SchedulingProtocolType. Valid values : A member of the SchedulingProtocolTypeenumeration, eitherEnhanceScheduleGroupLocalityorEnhanceForwardProgressDefault value : EnhanceScheduleGroupLocality | 
| TargetOversubscriptionFactor | Tentative number of virtual processors per hardware thread. The target oversubscription factor can be increased by the Resource Manager, if necessary, to satisfy MaxConcurrencywith the hardware threads on the machine.Valid values : Positive integers Default value : 1 | 
| WinRTInitialization | 
Requirements
Header: concrt.h
SchedulerType Enumeration
Used by the SchedulerKind policy to describe the type of threads that the scheduler should utilize for underlying execution contexts. For more information on available scheduler policies, see PolicyElementKey.
enum SchedulerType;
Values
| Name | Description | 
|---|---|
| ThreadScheduler | Indicates an explicit request of regular Win32 threads. | 
| UmsThreadDefault | User-mode schedulable (UMS) threads are not supported in the Concurrency Runtime in Visual Studio 2013. Using UmsThreadDefaultas a value for theSchedulerTypepolicy will not result in an error. However, a scheduler created with that policy will default to using Win32 threads. | 
Requirements
Header: concrt.h
SchedulingProtocolType Enumeration
Used by the SchedulingProtocol policy to describe which scheduling algorithm will be utilized for the scheduler. For more information on available scheduler policies, see PolicyElementKey.
enum SchedulingProtocolType;
Values
| Name | Description | 
|---|---|
| EnhanceForwardProgress | The scheduler prefers to round-robin through schedule groups after executing each task. Unblocked contexts are typically scheduled in a first-in-first-out (FIFO) fashion. Virtual processors do not cache unblocked contexts. | 
| EnhanceScheduleGroupLocality | The scheduler prefers to continue to work on tasks within the current schedule group before moving to another schedule group. Unblocked contexts are cached per virtual-processor and are typically scheduled in a last-in-first-out (LIFO) fashion by the virtual processor which unblocked them. | 
Requirements
Header: concrt.h
SwitchingProxyState Enumeration
Used to denote the state a thread proxy is in, when it is executing a cooperative context switch to a different thread proxy.
enum SwitchingProxyState;
Values
| Name | Description | 
|---|---|
| Blocking | Indicates that the calling thread is cooperatively blocking and should be exclusively owned by the caller until subsequently running again and performing other action. | 
| Idle | Indicates that the calling thread is no longer needed by the scheduler and is being returned to the Resource Manager. The context which was being dispatched is no longer able to be utilized by the Resource Manager. | 
| Nesting | Indicates that the calling thread is nesting a child scheduler and is needed by the caller, in order to attach to a different scheduler. | 
Remarks
A parameter of type SwitchingProxyState is passed in to the method IThreadProxy::SwitchTo to instruct the Resource Manager how to treat the thread proxy that is making the call.
For more information on how this type is used, see IThreadProxy::SwitchTo.
task_group_status Enumeration
Describes the execution status of a task_group or structured_task_group object. A value of this type is returned by numerous methods that wait on tasks scheduled to a task group to complete.
enum task_group_status;
Values
| Name | Description | 
|---|---|
| canceled | The task_grouporstructured_task_groupobject was canceled. One or more tasks may not have executed. | 
| completed | The tasks queued to the task_grouporstructured_task_groupobject completed successfully. | 
| not_complete | The tasks queued to the task_groupobject have not completed. Note that this value is not presently returned by the Concurrency Runtime. | 
Requirements
Header: pplinterface.h
WinRTInitializationType Enumeration
Used by the WinRTInitialization policy to describe whether and how the Windows Runtime will be initialized on scheduler threads for an application which runs on operating systems with version Windows 8 or higher. For more information on available scheduler policies, see PolicyElementKey.
enum WinRTInitializationType;
Values
| Name | Description | 
|---|---|
| DoNotInitializeWinRT | When the application is run on operating systems with version Windows 8 or higher, threads within the scheduler will not initialize the Windows Runtime . | 
| InitializeWinRTAsMTA | When the application is run on operating systems with version Windows 8 or higher, each thread within the scheduler will initialize the Windows Runtime and declare that it is part of the multithreaded apartment. | 
Requirements
Header: concrt.h