|
1 | 1 | /*
|
2 |
| - * Copyright (c) 2017, 2022, Oracle and/or its affiliates. All rights reserved. |
| 2 | + * Copyright (c) 2017, 2023, Oracle and/or its affiliates. All rights reserved. |
3 | 3 | * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
4 | 4 | *
|
5 | 5 | * This code is free software; you can redistribute it and/or modify it
|
|
25 | 25 | package sun.nio.ch;
|
26 | 26 |
|
27 | 27 | import java.io.IOException;
|
28 |
| -import java.util.ServiceConfigurationError; |
29 |
| -import sun.security.action.GetPropertyAction; |
30 | 28 |
|
| 29 | +/** |
| 30 | + * Provider class for Poller implementations. |
| 31 | + */ |
31 | 32 | abstract class PollerProvider {
|
| 33 | + private static final PollerProvider INSTANCE = new DefaultPollerProvider(); |
| 34 | + |
32 | 35 | PollerProvider() { }
|
33 | 36 |
|
34 | 37 | /**
|
35 |
| - * Returns true if threads should register file descriptors directly, |
36 |
| - * false to queue registrations to an updater thread. |
37 |
| - * |
38 |
| - * The default implementation returns false. |
| 38 | + * Returns the system-wide PollerProvider. |
39 | 39 | */
|
40 |
| - boolean useDirectRegister() { |
41 |
| - return false; |
| 40 | + static PollerProvider provider() { |
| 41 | + return INSTANCE; |
42 | 42 | }
|
43 | 43 |
|
44 | 44 | /**
|
45 |
| - * Creates a Poller for read ops. |
| 45 | + * Returns the default poller mode. |
| 46 | + * @implSpec The default implementation uses system threads. |
46 | 47 | */
|
47 |
| - abstract Poller readPoller() throws IOException; |
| 48 | + Poller.Mode defaultPollerMode() { |
| 49 | + return Poller.Mode.SYSTEM_THREADS; |
| 50 | + } |
48 | 51 |
|
49 | 52 | /**
|
50 |
| - * Creates a Poller for write ops. |
| 53 | + * Default number of read pollers for the given mode. The count must be a power of 2. |
| 54 | + * @implSpec The default implementation returns 1. |
51 | 55 | */
|
52 |
| - abstract Poller writePoller() throws IOException; |
| 56 | + int defaultReadPollers(Poller.Mode mode) { |
| 57 | + return 1; |
| 58 | + } |
53 | 59 |
|
54 | 60 | /**
|
55 |
| - * Creates the PollerProvider. |
| 61 | + * Default number of write pollers for the given mode. The count must be a power of 2. |
| 62 | + * @implSpec The default implementation returns 1. |
56 | 63 | */
|
57 |
| - static PollerProvider provider() { |
58 |
| - String cn = GetPropertyAction.privilegedGetProperty("jdk.PollerProvider"); |
59 |
| - if (cn != null) { |
60 |
| - try { |
61 |
| - Class<?> clazz = Class.forName(cn, true, ClassLoader.getSystemClassLoader()); |
62 |
| - return (PollerProvider) clazz.getConstructor().newInstance(); |
63 |
| - } catch (Exception e) { |
64 |
| - throw new ServiceConfigurationError(null, e); |
65 |
| - } |
66 |
| - } else { |
67 |
| - return new DefaultPollerProvider(); |
68 |
| - } |
| 64 | + int defaultWritePollers(Poller.Mode mode) { |
| 65 | + return 1; |
| 66 | + } |
| 67 | + |
| 68 | + /** |
| 69 | + * Maps a file descriptor to an index from 0 to {@code toIndex}. |
| 70 | + * @implSpec The default implementation is good for Unix file descriptors. |
| 71 | + */ |
| 72 | + int fdValToIndex(int fdVal, int toIndex) { |
| 73 | + return fdVal & (toIndex - 1); |
69 | 74 | }
|
| 75 | + |
| 76 | + /** |
| 77 | + * Creates a Poller for read ops. |
| 78 | + * @param subPoller true to create a sub-poller |
| 79 | + */ |
| 80 | + abstract Poller readPoller(boolean subPoller) throws IOException; |
| 81 | + |
| 82 | + /** |
| 83 | + * Creates a Poller for write ops. |
| 84 | + * @param subPoller true to create a sub-poller |
| 85 | + */ |
| 86 | + abstract Poller writePoller(boolean subPoller) throws IOException; |
70 | 87 | }
|
0 commit comments