aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media
Commit message (Collapse)AuthorAge
* ENGR00325572 v4l2 capture: fix build issue for built-in modulesOliver Brown2014-08-01
| | | | | | Fix a build error for built-int modules do to missing inline declaration Signed-off-by: Oliver Brown <oliver.brown@freescale.com>
* ENGR00321142 gis: faster auto standards detectionSandor Yu2014-07-15
| | | | | | | | | | | | | | | | Vadc need time to auto standards detection, the default standard is NTSC, if vadc connect to PAL camera and no enough time to detect the video mode, driver will get NTSC mode. Confirmation from chip design architecture auto detect function is not required by rear-view camera application. Setting register vdec_stddbg standard_filte bits to 0 makes the standard detection faster, the issue duplicate decrease to 1%. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00321733 csi: imx6sx: reinitialize csi when resumeRobby Cai2014-07-08
| | | | | | | | | | The CSI will be reset to initial state because dispmix takes effect and power off specific modules when suspend. Hence the reinitialization is needed when resume to make it work properly, otherwise the captured images are not correct. Signed-off-by: Robby Cai <r63905@freescale.com> (cherry picked from commit a9705bae9405bbf68a5db13a97e1d94e4ba15683)
* ENGR00321119 media: mxc: ADV7180: Support internal vidioc enum frame intervalsLiu Ying2014-07-03
| | | | | | | | This patch adds internal vidioc enum frame intervals support so that the user space may know the frame rate ADV7180 generates. Signed-off-by: Liu Ying <Ying.Liu@freescale.com> (cherry picked from commit 7de57c22a1a9ddd06166ffdb4d319fc5c1f6feb7)
* ENGR00321092 vadc: Add VIDIOC_ENUM_FRAMEINTERVALS supportSandor Yu2014-07-03
| | | | | | | Add VIDIOC_ENUM_FRAMEINTERVALS support for vadc driver. Signed-off-by: Sandor Yu <R01008@freescale.com> (cherry picked from commit 4863515c732d86589b7f2c9243c11c81669bd711)
* ENGR00320846 v4l2 capture: imx6sx: fix crash issue when rmmod csi_v4l2_captureRobby Cai2014-07-03
| | | | | | | | | | | | | | | | | | | | | | | | | | | | The reproduce steps: modprobe fsl_csi modprobe csi_v4l2_capture modprobe ov5640_camera modprobe mxc_vadc_tvin rmmod mxc_vadc_tvin rmmod ov5640_camera rmmod csi_v4l2_capture The kernel dump info: V4L2 freeing image input device Unable to handle kernel NULL pointer dereference at virtual address 00000018 pgd = a8f38000 [00000018] *pgd=a8713831, *pte=00000000, *ppte=00000000 Internal error: Oops: 17 [#1] PREEMPT SMP ARM Modules linked in: csi_v4l2_capture(-) fsl_csi ov5642_camera evbug [last unloaded: ov5640_camera] CPU: 0 PID: 804 Comm: rmmod Not tainted 3.10.31-1.1.0_beta+g3c16fd0 #1 task: a8bfb2c0 ti: a8bc4000 task.ti: a8bc4000 PC is at csi_v4l2_remove+0x14/0x80 [csi_v4l2_capture] LR is at platform_drv_remove+0x18/0x1c The cause is that only one global variable used for two instances in remove() function. This patch changed the global variable to local one to fix it. Signed-off-by: Robby Cai <r63905@freescale.com>
* ENGR00320056-2 vadc: imx6sx: assign the csi id in slave data structRobby Cai2014-06-28
| | | | | | | | Assign csi id in struct sensor_data of the slave, which will be used to judge if it need to be attached to the master. Signed-off-by: Robby Cai <r63905@freescale.com> (cherry picked from commit 7b5e2d4a158356e4290dcea3215b4a2438d0df6e)
* ENGR00320056-1 v4l2 capture: imx6sx: Add dual camera supportRobby Cai2014-06-28
| | | | | | | | | | | | | | | | | on imx6sx, there are two CSI ports which supports dual camera. The patch changes the framework for this support, including: - introduce a new struct csi_soc for multiple instances. - add csi_read and csi_write API with data type 'struct csi_soc *' to differentiate register access for each CSI. - add a new parameter 'cam_data *' for the csi_* API (except csi_dmareq_rff_enable/disable) for dual instances. - move 'input_fmt' and 'bswapenable' to struct _cam_data. - initialize cam->bswapenable' to false. - allocate dynamically memory for struce v4l2_int_device thus to differentiate each CSI port. Signed-off-by: Robby Cai <r63905@freescale.com> (cherry picked from commit 997d1e896eae21fb4c78495df1e01a126913cb53)
* ENGR00316536 vadc: Remove register setting that not define in specificationSandor Yu2014-06-13
| | | | | | Remove register setting that not define in specification. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00313867 media: mxc: ADV7180: Get standard when the chip is lockedLiu Ying2014-05-21
| | | | | | | | | | | | | | | The IN_LOCK bit of the ADV7180 register STATUS_1(0x10) indicates if the chip is locked or not in auto detection mode. We should get valid standard when the chip is locked, otherwise, invalid standard should be returned. This patch checks the IN_LOCK bit when we get standard in auto detection mode. Conflicts: drivers/media/video/mxc/capture/adv7180.c Signed-off-by: Liu Ying <Ying.Liu@freescale.com> (cherry picked from commit c0d94e51b331002c11ebdfc8a559c8ec878894d6)
* ENGR00313888 vadc: Enable Chroma AGC Control registerSandor Yu2014-05-18
| | | | | | | Add register LMAGC1 and CHAGC1 that missing in i.MX6sx RM. Enable chroma AGC function. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00312702-1 csi v4l2 capture: Pass overlay parameter to pxp dmaSandor Yu2014-05-12
| | | | | | | Pass overlay parameter to pxp dma, otherwise struct of ol_param will remain the value as last pxp task. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00311686 csi v4l2 capture: enable swap functionSandor Yu2014-05-12
| | | | | | | Enable csi data swap function when csi v4l2 need do csc between YUYV and UYVY. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00311092 v4l2 capture: Add width and height zero checkSandor Yu2014-05-04
| | | | | | | | Add width and height zero check to avoid kernel dump by the error "Division by zero in kernel" when user application call the s_fmt api with zero height and width Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00309489-2 v4l2 capture: Change code that violate v4l2 apiSandor Yu2014-04-24
| | | | | | | | | -Remove parameter crop_current and replace by cam->crop_current. -Remove parameter win_current and update pxp buffer initialize code. -Move csi config code from s_fmt function to s_param. -Correct crop_bound setting for vadc. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00309489-1 vadc: replace raw lines with active linesSandor Yu2014-04-24
| | | | | | | | | Replace raw lines with active lines. return active lines to v4l2 capture driver. For csi capture driver, the capture size is setting to active lines and don't care raw lines. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00301281 media: mxc vout: set input resolution back after PP check/processLiu Ying2014-04-23
| | | | | | | | | | | | | | | | | | | | In VDOA PP mode, the input resolution would be changed to be VDOA's output for PP to use as its input resolution to go on to do resizing or color space conversion. The input resolution will be different from the original one when VDOA input cropping is enabled. And, this finally causes a wrong input resolution being used if the users do rotation by calling the S_CTRL ioctrl in runtime. In order to fix this issue, this patch sets the original input resolution back after PP task check and process. The issue can be reproduced by the following command line(enable VDOA mode in the gst plugin configuration file first): gplay AVC_MP30_854x356_23.976_679_AACLC_44.1_96_2_TRON_LEGACY.flv (Enter 't 90' to change to rotate 90 degrees in runtime.) In this case, VDOA input cropping(854x356 -> 848x352) is enabled because VDOA input resolution should align to macro block size. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00307014-06 vadc: Enable vadc functionSandor Yu2014-04-17
| | | | | | | Enable vadc function. That can work at PAL 720x576 and NTSC 720x480 mode. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00307014-03 v4l2 capture: support for vadcSandor Yu2014-04-17
| | | | | | | | | -Add v4l2 capture ioctl VIDIOC_S_INPUT, VIDIOC_G_INPUT,VIDIOC_ENUMINPUT, VIDIOC_S_STD,VIDIOC_G_STD support. -Add NTSC, PAL format define. -Add parameter cam_input_fmt to save camera sensor format. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00307014-02 csi: update csi driver to support vadcSandor Yu2014-04-17
| | | | | | | | -Add csi control register 18 define. -Add csi_tvdec_enable and csi_deinterlace_mode for vadc. -Add csi_set_32bit_imagpara function to support YUV444 format. Signed-off-by: Sandor Yu <R01008@freescale.com>
* ENGR00304418 [V4l2][PXP] Add some rotation cases support for V4L app.Fancy Fang2014-04-16
| | | | | | | | Some V4L2 apps require that playing rotated fullscreen video on the screen. In recent PXP driver, this is not supported yet. So this patch adds it on through combining rotation and resize together. Signed-off-by: Fancy Fang <chen.fang@freescale.com>
* ENGR00301270 [V4L2 Capture] PXP V4L2 output can't report absolute physical ↵Fancy Fang2014-04-16
| | | | | | | | | | address. Add absolute physical address report by V4L2 driver after this buffer has been mapped, which is requested by some multimedia applications. Signed-off-by: Fancy Fang <chen.fang@freescale.com>
* ENGR00305067-2 media: v4l2: mxc pxp output: Weaken fb id checkLiu Ying2014-04-16
| | | | | | | | This patch uses strncmp() to replace strcmp() to weaken framebuffer id check so that the mxs framebuffer driver may use different names for standalone framebuffers. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00300658-6 csi: imx6sx: add clock handling in driverRobby Cai2014-04-16
| | | | | | | | | | | | | | According to IC team, DCIC1 clock is used in the IPSYNC for CSI1 and DCIC2 clock is used in the IPSYNC for the CSI2. So dcic clock is needed for CSI. The display axi clock is a clock gating newly added on imx6sx. It needs to be enabled for lcdif/pxp/csi/pcie to work. CSI clock seems to be implemented different other than other SoCs. It needs also to be enabled before access the registers, otherwise the system will hang. Signed-off-by: Robby Cai <R63905@freescale.com>
* ENGR00300658-4 csi: imx6sx: add CSI_ENABLE bit control in driverRobby Cai2014-04-16
| | | | | | | on imx6sx, a new bit CSI_ENABLE is added in IC design. This patch adds this support for CSI control. Signed-off-by: Robby Cai <R63905@freescale.com>
* ENGR00303663 mxc v4l2 capture: Don't return error if we cannot get mipi csi2Liu Ying2014-04-16
| | | | | | | | | | | | | | | | | The mipi csi2 code is ugly present in the capture pipeline setup/disable routions with '#ifdef CONFIG_MXC_MIPI_CSI2/#endif' protected. Whenever it finds mipi_csi2_info is not gotten correctly, it will return error to callers. This breaks the normally routines in which mipi csi2 is not used and mipi csi2 driver is disabled in its devicetree node(but with the Kconfig CONFIG_MXC_MIPI_CSI2 defined). A real example is the capture feature on the MX6 Sabreauto platforms. We have only parallel CSI input on it and the mipi csi2 driver is disabled in its devicetree node but with the Kconfig CONFIG_MXC_MIPI_CSI2 defined. So, a reasonable choice at present is not to return error if mipi_csi2_info cannot be gotten, though we could eventually re-organize the capture code for a better total solution in the future. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00243315-4 MXC V4L2 Capture:Improve debug info for s_stdLiu Ying2014-04-16
| | | | | | | | | | | | | commit f8e1a3bb62eecf93a31a51c4dbe08a0214fa1d57 introduced an annoying kernel log by changing a pure debug info to error level. This patch reverts that change. Conflicts: drivers/media/video/mxc/capture/mxc_v4l2_capture.c Signed-off-by: Liu Ying <Ying.Liu@freescale.com> (cherry picked from commit 289cc885ae097bbf9849cb266679a2969e5c39a9)
* ENGR00243315-3 MXC V4L2 Capture:Remove unnecessary mclk settingLiu Ying2014-04-16
| | | | | | | | | | | | | | | | commit f8e1a3bb62eecf93a31a51c4dbe08a0214fa1d57 added a hard coding for csi_parma.mclk setting to 27MHz. The comment added by that commit is totally wrong by telling that csi_param.mclk would be a kind of 'pixel clock' set in 'csi_data_dest' register. This patch removes the unnecessary mclk setting for csi_param.mclk variable, since it is only valid for CSI test mode. Conflicts: drivers/media/video/mxc/capture/mxc_v4l2_capture.c Signed-off-by: Liu Ying <Ying.Liu@freescale.com> (cherry picked from commit 5fed1e3fde2d63c80f414f204734d35ceecef561)
* ENGR00299224 ov5640 mipi: support internal enum_frameintervals ioctrlLiu Ying2014-04-16
| | | | | | | This patch adds internal v4l2 enum_frameintervals ioctrl support for the ov5640 mipi camera driver. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00299214 mxc v4l2 capture: support VIDIOC_ENUM_FRAMEINTERVALS ioctlLiu Ying2014-04-16
| | | | | | | This patch adds VIDIOC_ENUM_FRAMEINTERVALS ioctl support for the mxc v4l2 capture driver. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00293132-2 pxp/v4l2: restore smem_start for framebuffer even exit abnormallyRobby Cai2014-04-16
| | | | | | | | | | Previously, the framebuffer for UI display may only be restored after STREAMOFF ioctl is called. But sometimes the application may exit abnormally (without call STREAMOFF) for some reason. Now restore previously-saved smem_start in release function to make sure it's set correctly, to avoid some video frame remain. Signed-off-by: Robby Cai <R63905@freescale.com>
* ENGR00293132-1 pxp/v4l2: change memory alloc policy for PxP output bufferRobby Cai2014-04-16
| | | | | | | | | | In previous implementation, the memory allocation/free for PxP output buffer is done each time v4l2 output device is opened/closed. This is not necessary and may cause memory fragmentation issue after running many many times. Now we re-allocate the memory for it only if the existing memory size is not sufficent for new case. Signed-off-by: Robby Cai <R63905@freescale.com>
* ENGR00291843 V4L2_PXP: fix a dangling pointer accessing issueFancy Fang2014-04-16
| | | | | | | After dynamically alloc/free tx descriptors enabled, the descriptors will be freed in PXP ISR which happens before pxp_buf_free() is called. Signed-off-by: Fancy Fang <B47543@freescale.com>
* ENGR00291111 mxc vout:Restore when new config failsLiu Ying2014-04-16
| | | | | | | | | | | | | | | Users may call VIDIOC_S_CTRL and VIDIOC_S_CROP ioctrls to change rotation and cropping settings when streaming. The driver should restore the original settings if new configuration fails, otherwise, it might break the present pipeline. This patch fixes the issue which can be reproduced by this test case with a 1080P HDMI primary display: gplay Mpeg4_SP1_480x260_24_1200_aac_48_128_2_terminator3.mp4 Type 't' to set rotation to 90. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00290635-1 mxc vout:Fix a build warningLiu Ying2014-04-16
| | | | | | | | | | This patch fixes the following build warning by allocating a block of virtual memory to cache an instance of the structure mxc_vout_output instead of using the stack frame. drivers/media/platform/mxc/output/mxc_vout.c: In function ‘mxc_vidioc_s_crop’: drivers/media/platform/mxc/output/mxc_vout.c:1529:1: warning: the frame size of 1040 bytes is larger than 1024 bytes [-Wframe-larger-than=] Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00289648 mx6sl: v4l2 output: Add UYVY format as input format for v4l2Robby Cai2014-04-16
| | | | | | | | | This feature is easy for gstreamer to pipeline v4lsrc and v4lsink, since camera output format can be set as UYVY in v4l2 capture driver, and PxP will do the CSC from UYVY to RGB565 in v4l2 output driver for LCD display. Signed-off-by: Robby Cai <R63905@freescale.com> (cherry picked from commit d8f47ca83385f3e96ce457f35b69c4a7ac733a6e)
* ENGR00289436 - [V4L2 Capture] Build warning on mxc_v4l2_capture.cOliver Brown2014-04-16
| | | | | | | | | | | | | Need to remove the following warning: warning: array subscript is above array bounds Summary of changes: Moved MXC_SENSOR_NUM definition to mxc_v4l2_capture.h. all_sensors[] now uses MXC_SENSOR_NUM in definition. MXC_SENSOR_NUM is now used for bounds checking the array. Signed-off-by: Oliver Brown <oliver.brown@freescale.com>
* ENGR00279204-2 mxc vout: reconfig overlay fb correctlyLiu Ying2014-04-16
| | | | | | | | | | | | | | | | | | | The overlay framebuffer's position and resolution are set with two different APIs. They depend on each other to make sure the overlay framebuffer window will not go out of the background framebuffer window. Potentially, this causes the overlay framebuffer's position or resolution of the current video pipeline be impacted by the settings of the last time. To setup the overlay fb from scratch correctly, this patch takes the following steps: - blank framebuffer - set framebuffer position to the starting point - reconfigure framebuffer - set framebuffer position to a specific point - unblank framebuffer This procedure applies to non-overlay framebuffers as well. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00279204-1 mxc vout: reconfig fb when necessaryLiu Ying2014-04-16
| | | | | | | | | | | | | | | | | Users may call VIDIOC_S_CTRL or VIDIOC_S_CROP ioctrls to update streaming parameters on-the-fly after video has been streamed on, such as for rotation/output resolution/overlay output position change. Any unnecessary frame buffer reconfiguration would cause a pair of frame buffer blank/unblank events happen and even makes the background framebuffer show up for a short period of time if the video is rendered on an overlay framebuffer. This patch compares the last time video output pipe line settings with the current ones to determine whether frame buffer reconfiguration is necessary or not. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00280140 pxp/v4l2: restore the display content after video playback finishesRobby Cai2014-04-16
| | | | | | | | | | | | | | | | | After finish video playback, the last frame remains on the display. It's because the UI display start address (smem_start) has been changed when do video playback but not changed back again after the playback finishes. From the function call point of view, pxp_set_fbinfo() // pxp->fb.base tracks right addr for UI framebuffer pxp_show_buf(toshow) // smem_start changed to v4l2 display addr pxp_set_fbinfo() // pxp->fb.base changed to v4l2 display addr pxp_show_buf(not toshow) // smem_start still equal to v4l2 display addr // for pan_display This patch fixes it by calling pxp_set_fbinfo once in open function. Signed-off-by: Robby Cai <R63905@freescale.com>
* ENGR00280663-3 mxc vout: handle downsize ratio overflowLiu Ying2014-04-16
| | | | | | | This patch handles downsize ratio overflow error by doing input cropping with 8 pixel step. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00280115 videobuf-dma-contig: make mmapped video buffer bufferableLiu Ying2014-04-16
| | | | | | | This patch makes mmapped video buffers bufferable so that software decoders may render the video buffers efficiently. Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00279413 pxp/v4l2: get the right framebuffer start address at run timeRobby Cai2014-04-16
| | | | | | | | | | | Previously the driver gets the framebuffer start address at probe time. But this address might be changed if the framebuffer drivers re-allocate the frame buffers due to the application changes the yres_virtual. As a result, some garbage data can be observed on display. This patch adjusts the way to detect the start address at run time to fix this problem. Signed-off-by: Robby Cai <R63905@freescale.com>
* ENGR00279401 mxc v4l2 capture: use flush_work instead of flush_work_syncLiu Ying2014-04-16
| | | | | | | Since commit 43829731d (workqueue: deprecate flush[_delayed]_work_sync()), flush_work() should be used instead of flush_work_sync(). Signed-off-by: Liu Ying <Ying.Liu@freescale.com>
* ENGR00279226 media: ov5642: correct io_regulator sanity checkLiu Ying2014-04-16
| | | | | | | | | | | The following commit introduced a wrong sanity check for the io_regulator which is intended to be got from device tree. a364635a535705a8c16df49ff9bc7b9362b083ec This patch corrects the sanity check. Signed-off-by: Liu Ying <Ying.Liu@freescale.com> (cherry picked from commit a0ff4d112dcd8a71547f2b95731f2fedb21a77e4)
* ENGR00278667-1 [mxc_v4l2_capture]: Add adv7180 driver in 3.10.9 KernelOliver Brown2014-04-16
| | | | | | | | | | | Copied file from 3.5.7 Kernel commit de6459732a23402cbe520812bf4202299330fd68 Author: Oliver Brown <oliver.brown@freescale.com> Date: Mon Jun 24 16:41:17 2013 -0500 Added missing call to clk_disable_unprepare() in adv7180_probe. Signed-off-by: Oliver Brown <oliver.brown@freescale.com>
* ENGR00278665-1 [mxc_v4l2_capture]: Add ov5640_mipi driver filesOliver Brown2014-04-16
| | | | | | | | | | | | | | | | Copied file from 3.5.7 Kernel: commit 0682e12bf9a3b5085fe5dd70574fe856340894d0 Author: Liu Ying <Ying.Liu@freescale.com> Date: Thu May 16 12:02:14 2013 +0800 -Added function and file name to some error messages that are in multiple places. -Added calls to clk_prepare_enable() and clk_disable_unprepare() in ov5640_probe() to manage the sensor clock. -Added missing sanity check for "io_regulator" -Fixed several whitespace errors Signed-off-by: Oliver Brown <oliver.brown@freescale.com>
* ENGR00279087-2 csi_v4l2_capture: move int_dev_init() to open functionRobby Cai2014-04-16
| | | | | | | | | | | | | | | | | | | | | By later initialization for camera dev (to call int_dev_init), the driver works well whether the master (csi_v4l2_capture) or the slave (ov5640) has been attached first. In this way, the driver can stick to the philosophy for the V4L2_INT_DEVICE framework (the attach sequence shouldn't matter). The following way to insert modules should work: $ insmod fsl_csi.ko $ insmod ov5640_camera.ko $ insmod csi_v4l2_capture.ko or, $ insmod fsl_csi.ko $ insmod csi_v4l2_capture.ko $ insmod ov5640_camera.ko Signed-off-by: Robby Cai <R63905@freescale.com>
* ENGR00279087-1 camera: enable mclk before read the camera IDRobby Cai2014-04-16
| | | | | | | | | | | | | | | | | When the camera driver is built as module and done 'insmod' command, the camera will not be detected. The error message is as follows. $ insmod ov5640_camera.ko ov5640 2-003c: cannot get io voltage ov5640_read_reg:write reg error:reg=300a camera ov5640 is not found The reason is the mclk need to be enabled before read camera registers. This patch fixes it. To balance the usecount for the mclk, we need disable the mclk afterwards. Signed-off-by: Robby Cai <R63905@freescale.com>
* ENGR00278666-1 [mxc_v4l2_capture]: Add ov5642 driver files in 3.10.9 KernelOliver Brown2014-04-16
| | | | | | | | | | | | | Copied file from 3.5.7 Kernel: commit 0682e12bf9a3b5085fe5dd70574fe856340894d0 Author: Liu Ying <Ying.Liu@freescale.com> Date: Thu May 16 12:02:14 2013 +0800 -Added calls to clk_prepare_enable() and clk_disable_unprepare() in ov5642_probe() to manage the sensor clock. -Fixed whitespace errors Signed-off-by: Oliver Brown <oliver.brown@freescale.com>