… | |
… | |
336 | =item * Structures are often specified by flattening out their components |
336 | =item * Structures are often specified by flattening out their components |
337 | as with short vectors, and returned as arrayrefs. |
337 | as with short vectors, and returned as arrayrefs. |
338 | |
338 | |
339 | =item * When enqueuing commands, the wait list is specified by adding |
339 | =item * When enqueuing commands, the wait list is specified by adding |
340 | extra arguments to the function - anywhere a C<$wait_events...> argument |
340 | extra arguments to the function - anywhere a C<$wait_events...> argument |
341 | is documented this can be any number of event objects. |
341 | is documented this can be any number of event objects. As an extsnion |
|
|
342 | implemented by this module, C<undef> values will be ignored in the event |
|
|
343 | list. |
342 | |
344 | |
343 | =item * When enqueuing commands, if the enqueue method is called in void |
345 | =item * When enqueuing commands, if the enqueue method is called in void |
344 | context, no event is created. In all other contexts an event is returned |
346 | context, no event is created. In all other contexts an event is returned |
345 | by the method. |
347 | by the method. |
346 | |
348 | |
… | |
… | |
748 | |
750 | |
749 | =item @device_partition_property_exts = $device->affinity_domains_ext |
751 | =item @device_partition_property_exts = $device->affinity_domains_ext |
750 | |
752 | |
751 | Calls C<clGetDeviceInfo> with C<CL_DEVICE_AFFINITY_DOMAINS_EXT> and returns the result. |
753 | Calls C<clGetDeviceInfo> with C<CL_DEVICE_AFFINITY_DOMAINS_EXT> and returns the result. |
752 | |
754 | |
753 | =item $uint = $device->reference_count_ext |
755 | =item $uint = $device->reference_count_ext |
754 | |
756 | |
755 | Calls C<clGetDeviceInfo> with C<CL_DEVICE_REFERENCE_COUNT_EXT > and returns the result. |
757 | Calls C<clGetDeviceInfo> with C<CL_DEVICE_REFERENCE_COUNT_EXT> and returns the result. |
756 | |
758 | |
757 | =item @device_partition_property_exts = $device->partition_style_ext |
759 | =item @device_partition_property_exts = $device->partition_style_ext |
758 | |
760 | |
759 | Calls C<clGetDeviceInfo> with C<CL_DEVICE_PARTITION_STYLE_EXT> and returns the result. |
761 | Calls C<clGetDeviceInfo> with C<CL_DEVICE_PARTITION_STYLE_EXT> and returns the result. |
760 | |
762 | |
… | |
… | |
769 | =item $queue = $ctx->queue ($device, $properties) |
771 | =item $queue = $ctx->queue ($device, $properties) |
770 | |
772 | |
771 | Create a new OpenCL::Queue object from the context and the given device. |
773 | Create a new OpenCL::Queue object from the context and the given device. |
772 | |
774 | |
773 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clCreateCommandQueue.html> |
775 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clCreateCommandQueue.html> |
|
|
776 | |
|
|
777 | Example: create an out-of-order queue. |
|
|
778 | |
|
|
779 | $queue = $ctx->queue ($device, OpenCL::QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE); |
774 | |
780 | |
775 | =item $ev = $ctx->user_event |
781 | =item $ev = $ctx->user_event |
776 | |
782 | |
777 | Creates a new OpenCL::UserEvent object. |
783 | Creates a new OpenCL::UserEvent object. |
778 | |
784 | |
… | |
… | |
809 | Creates a new OpenCL::Buffer (actually OpenCL::BufferObj) object that refers to the given |
815 | Creates a new OpenCL::Buffer (actually OpenCL::BufferObj) object that refers to the given |
810 | OpenGL buffer object. |
816 | OpenGL buffer object. |
811 | |
817 | |
812 | http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clCreateFromGLBuffer.html |
818 | http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clCreateFromGLBuffer.html |
813 | |
819 | |
|
|
820 | =item $img = $ctx->gl_texture ($flags, $target, $miplevel, $texture) |
|
|
821 | |
|
|
822 | Creates a new OpenCL::Image object that refers to the given OpenGL |
|
|
823 | texture object or buffer. |
|
|
824 | |
|
|
825 | http://www.khronos.org/registry/cl/sdk/1.2/docs/man/xhtml/clCreateFromGLTexture.html |
|
|
826 | |
814 | =item $ctx->gl_texture2d ($flags, $target, $miplevel, $texture) |
827 | =item $img = $ctx->gl_texture2d ($flags, $target, $miplevel, $texture) |
815 | |
828 | |
816 | Creates a new OpenCL::Image2D object that refers to the given OpenGL |
829 | Creates a new OpenCL::Image2D object that refers to the given OpenGL |
817 | 2D texture object. |
830 | 2D texture object. |
818 | |
831 | |
819 | http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clCreateFromGLTexture2D.html |
832 | http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clCreateFromGLTexture2D.html |
820 | |
833 | |
821 | =item $ctx->gl_texture3d ($flags, $target, $miplevel, $texture) |
834 | =item $img = $ctx->gl_texture3d ($flags, $target, $miplevel, $texture) |
822 | |
835 | |
823 | Creates a new OpenCL::Image3D object that refers to the given OpenGL |
836 | Creates a new OpenCL::Image3D object that refers to the given OpenGL |
824 | 3D texture object. |
837 | 3D texture object. |
825 | |
838 | |
826 | http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clCreateFromGLTexture3D.html |
839 | http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clCreateFromGLTexture3D.html |
… | |
… | |
889 | for completion, unless the method is called in void context, in which case |
902 | for completion, unless the method is called in void context, in which case |
890 | no event object is created. |
903 | no event object is created. |
891 | |
904 | |
892 | They also allow you to specify any number of other event objects that this |
905 | They also allow you to specify any number of other event objects that this |
893 | request has to wait for before it starts executing, by simply passing the |
906 | request has to wait for before it starts executing, by simply passing the |
894 | event objects as extra parameters to the enqueue methods. |
907 | event objects as extra parameters to the enqueue methods. To simplify |
|
|
908 | program design, this module ignores any C<undef> values in the list of |
|
|
909 | events. This makes it possible to code operations such as this, without |
|
|
910 | having to put a valid event object into C<$event> first: |
|
|
911 | |
|
|
912 | $event = $queue->enqueue_xxx (..., $event); |
895 | |
913 | |
896 | Queues execute in-order by default, without any parallelism, so in most |
914 | Queues execute in-order by default, without any parallelism, so in most |
897 | cases (i.e. you use only one queue) it's not necessary to wait for or |
915 | cases (i.e. you use only one queue) it's not necessary to wait for or |
898 | create event objects. |
916 | create event objects, althoguh an our of order queue is often a bit |
|
|
917 | faster. |
899 | |
918 | |
900 | =over 4 |
919 | =over 4 |
901 | |
920 | |
902 | =item $ev = $queue->enqueue_read_buffer ($buffer, $blocking, $offset, $len, $data, $wait_events...) |
921 | =item $ev = $queue->enqueue_read_buffer ($buffer, $blocking, $offset, $len, $data, $wait_events...) |
903 | |
922 | |
… | |
… | |
969 | reference to an array of local work sizes, with the same number of |
988 | reference to an array of local work sizes, with the same number of |
970 | elements as @$global_work_size. |
989 | elements as @$global_work_size. |
971 | |
990 | |
972 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clEnqueueNDRangeKernel.html> |
991 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clEnqueueNDRangeKernel.html> |
973 | |
992 | |
974 | =item $ev = $queue->enqueue_marker ($wait_events...) |
|
|
975 | |
|
|
976 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clEnqueueMarker.html> |
|
|
977 | |
|
|
978 | =item $ev = $queue->enqueue_acquire_gl_objects ([object, ...], $wait_events...) |
993 | =item $ev = $queue->enqueue_acquire_gl_objects ([object, ...], $wait_events...) |
979 | |
994 | |
980 | Enqueues a list (an array-ref of OpenCL::Memory objects) to be acquired |
995 | Enqueues a list (an array-ref of OpenCL::Memory objects) to be acquired |
981 | for subsequent OpenCL usage. |
996 | for subsequent OpenCL usage. |
982 | |
997 | |
… | |
… | |
991 | |
1006 | |
992 | =item $ev = $queue->enqueue_wait_for_events ($wait_events...) |
1007 | =item $ev = $queue->enqueue_wait_for_events ($wait_events...) |
993 | |
1008 | |
994 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clEnqueueWaitForEvents.html> |
1009 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clEnqueueWaitForEvents.html> |
995 | |
1010 | |
996 | =item $queue->enqueue_barrier |
1011 | =item $ev = $queue->enqueue_marker ($wait_events...) |
997 | |
1012 | |
|
|
1013 | L<http://www.khronos.org/registry/cl/sdk/1.2/docs/man/xhtml/clEnqueueMarkerWithWaitList.html> |
|
|
1014 | |
|
|
1015 | =item $ev = $queue->enqueue_barrier ($wait_events...) |
|
|
1016 | |
998 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clEnqueueBarrier.html> |
1017 | L<http://www.khronos.org/registry/cl/sdk/1.2/docs/man/xhtml/clEnqueueBarrierWithWaitList.html> |
999 | |
1018 | |
1000 | =item $queue->flush |
1019 | =item $queue->flush |
1001 | |
1020 | |
1002 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clFlush.html> |
1021 | L<http://www.khronos.org/registry/cl/sdk/1.1/docs/man/xhtml/clFlush.html> |
1003 | |
1022 | |
… | |
… | |
1118 | |
1137 | |
1119 | =back |
1138 | =back |
1120 | |
1139 | |
1121 | =head2 THE OpenCL::Image CLASS |
1140 | =head2 THE OpenCL::Image CLASS |
1122 | |
1141 | |
1123 | This is the superclass of all image objects - OpenCL::Image2D and OpenCL::Image3D. |
1142 | This is the superclass of all image objects - OpenCL::Image1D, |
|
|
1143 | OpenCL::Image1DArray, OpenCL::Image1DBuffer, OpenCL::Image2D, |
|
|
1144 | OpenCL::Image2DArray and OpenCL::Image3D. |
1124 | |
1145 | |
1125 | =over 4 |
1146 | =over 4 |
1126 | |
1147 | |
1127 | =item $packed_value = $ev->image_info ($name) |
1148 | =item $packed_value = $ev->image_info ($name) |
1128 | |
1149 | |
… | |
… | |
1479 | our $VERSION = '0.96'; |
1500 | our $VERSION = '0.96'; |
1480 | |
1501 | |
1481 | require XSLoader; |
1502 | require XSLoader; |
1482 | XSLoader::load (__PACKAGE__, $VERSION); |
1503 | XSLoader::load (__PACKAGE__, $VERSION); |
1483 | |
1504 | |
1484 | @OpenCL::Buffer::ISA = |
1505 | @OpenCL::Buffer::ISA = |
1485 | @OpenCL::Image::ISA = OpenCL::Memory::; |
1506 | @OpenCL::Image::ISA = OpenCL::Memory::; |
1486 | |
1507 | |
1487 | @OpenCL::BufferObj::ISA = OpenCL::Buffer::; |
1508 | @OpenCL::BufferObj::ISA = OpenCL::Buffer::; |
1488 | |
1509 | |
1489 | @OpenCL::Image2D::ISA = |
1510 | @OpenCL::Image2D::ISA = |
|
|
1511 | @OpenCL::Image3D::ISA = |
|
|
1512 | @OpenCL::Image2DArray::ISA = |
|
|
1513 | @OpenCL::Image1D::ISA = |
|
|
1514 | @OpenCL::Image1DArray::ISA = |
1490 | @OpenCL::Image3D::ISA = OpenCL::Image::; |
1515 | @OpenCL::Image1DBuffer::ISA = OpenCL::Image::; |
1491 | |
1516 | |
1492 | @OpenCL::UserEvent::ISA = OpenCL::Event::; |
1517 | @OpenCL::UserEvent::ISA = OpenCL::Event::; |
1493 | } |
1518 | } |
1494 | |
1519 | |
1495 | 1; |
1520 | 1; |
1496 | |
1521 | |
1497 | =head1 AUTHOR |
1522 | =head1 AUTHOR |