Home
last modified time | relevance | path

Searched refs:dev (Results 1 – 25 of 5566) sorted by relevance

12345678910>>...223

/third_party/uboot/u-boot-2020.01/fs/yaffs2/
Dyaffs_checkptrw.c17 static int yaffs2_checkpt_space_ok(struct yaffs_dev *dev) in yaffs2_checkpt_space_ok() argument
19 int blocks_avail = dev->n_erased_blocks - dev->param.n_reserved_blocks; in yaffs2_checkpt_space_ok()
27 static int yaffs_checkpt_erase(struct yaffs_dev *dev) in yaffs_checkpt_erase() argument
31 if (!dev->param.erase_fn) in yaffs_checkpt_erase()
35 dev->internal_start_block, dev->internal_end_block); in yaffs_checkpt_erase()
37 for (i = dev->internal_start_block; i <= dev->internal_end_block; i++) { in yaffs_checkpt_erase()
38 struct yaffs_block_info *bi = yaffs_get_block_info(dev, i); in yaffs_checkpt_erase()
43 dev->n_erasures++; in yaffs_checkpt_erase()
45 if (dev->param. in yaffs_checkpt_erase()
46 erase_fn(dev, in yaffs_checkpt_erase()
[all …]
Dyaffs_guts.c47 void yaffs_addr_to_chunk(struct yaffs_dev *dev, loff_t addr, in yaffs_addr_to_chunk() argument
53 chunk = (u32) (addr >> dev->chunk_shift); in yaffs_addr_to_chunk()
55 if (dev->chunk_div == 1) { in yaffs_addr_to_chunk()
57 offset = (u32) (addr & dev->chunk_mask); in yaffs_addr_to_chunk()
63 chunk /= dev->chunk_div; in yaffs_addr_to_chunk()
65 chunk_base = ((loff_t) chunk) * dev->data_bytes_per_chunk; in yaffs_addr_to_chunk()
123 static int yaffs_init_tmp_buffers(struct yaffs_dev *dev) in yaffs_init_tmp_buffers() argument
128 memset(dev->temp_buffer, 0, sizeof(dev->temp_buffer)); in yaffs_init_tmp_buffers()
131 dev->temp_buffer[i].in_use = 0; in yaffs_init_tmp_buffers()
132 buf = kmalloc(dev->param.total_bytes_per_chunk, GFP_NOFS); in yaffs_init_tmp_buffers()
[all …]
/third_party/libinput/test/
Dtest-touchpad-buttons.c37 struct litest_device *dev = litest_current_device(); in START_TEST() local
38 struct libinput *li = dev->libinput; in START_TEST()
40 if (!libevdev_has_event_code(dev->evdev, EV_KEY, BTN_LEFT)) in START_TEST()
45 litest_button_click(dev, BTN_LEFT, true); in START_TEST()
50 litest_button_click(dev, BTN_LEFT, false); in START_TEST()
60 struct litest_device *dev = litest_current_device(); in START_TEST() local
61 struct libinput_device *device = dev->libinput_device; in START_TEST()
87 struct litest_device *dev = litest_current_device(); in START_TEST() local
88 struct libinput_device *device = dev->libinput_device; in START_TEST()
114 struct litest_device *dev = litest_current_device(); in START_TEST() local
[all …]
Dtest-touchpad-tap.c37 struct litest_device *dev = litest_current_device(); in START_TEST() local
38 struct libinput *li = dev->libinput; in START_TEST()
40 litest_enable_tap(dev->libinput_device); in START_TEST()
44 litest_touch_down(dev, 0, 50, 50); in START_TEST()
45 litest_touch_up(dev, 0); in START_TEST()
61 struct litest_device *dev = litest_current_device(); in START_TEST() local
62 struct libinput *li = dev->libinput; in START_TEST()
67 litest_enable_tap(dev->libinput_device); in START_TEST()
71 litest_touch_down(dev, 0, 50, 50); in START_TEST()
73 litest_touch_up(dev, 0); in START_TEST()
[all …]
Dtest-touchpad.c58 struct litest_device *dev = litest_current_device(); in START_TEST() local
59 struct libinput *li = dev->libinput; in START_TEST()
63 litest_disable_tap(dev->libinput_device); in START_TEST()
67 litest_touch_down(dev, 0, 50, 50); in START_TEST()
68 litest_touch_move_to(dev, 0, 50, 50, 80, 50, 20); in START_TEST()
69 litest_touch_up(dev, 0); in START_TEST()
91 struct litest_device *dev = litest_current_device(); in START_TEST() local
92 struct libinput *li = dev->libinput; in START_TEST()
95 libinput_device_config_tap_set_enabled(dev->libinput_device, in START_TEST()
100 litest_touch_down(dev, 0, 20, 20); in START_TEST()
[all …]
/third_party/libevdev/libevdev/
Dlibevdev.c63 static int sync_mt_state(struct libevdev *dev,
66 update_key_state(struct libevdev *dev, const struct input_event *e);
69 slot_value(const struct libevdev *dev, int slot, int axis) in slot_value() argument
71 if (unlikely(slot > dev->num_slots)) { in slot_value()
72 log_bug(dev, "Slot %d exceeds number of slots (%d)\n", slot, dev->num_slots); in slot_value()
76 log_bug(dev, "MT axis %d is outside the valid range [%d,%d]\n", in slot_value()
80 return &dev->mt_slot_vals[slot * ABS_MT_CNT + axis - ABS_MT_MIN]; in slot_value()
84 init_event_queue(struct libevdev *dev) in init_event_queue() argument
99 if (libevdev_has_event_code(dev, type, code)) in init_event_queue()
104 nslots = libevdev_get_num_slots(dev); in init_event_queue()
[all …]
/third_party/NuttX/drivers/pipes/
Dpipe_common.c112 static void pipecommon_pollnotify(struct pipe_dev_s *dev, in pipecommon_pollnotify() argument
120 notify_poll_with_key(&dev->wq, eventset); in pipecommon_pollnotify()
133 struct pipe_dev_s *dev = NULL; in pipecommon_allocdev() local
143 dev = (struct pipe_dev_s *)malloc(sizeof(struct pipe_dev_s)); in pipecommon_allocdev()
144 if (dev) in pipecommon_allocdev()
148 (void)memset_s(dev, sizeof(struct pipe_dev_s), 0, sizeof(struct pipe_dev_s)); in pipecommon_allocdev()
149 ret = strcpy_s(dev->name, sizeof(dev->name), name); in pipecommon_allocdev()
152 free(dev); in pipecommon_allocdev()
155 sem_init(&dev->d_bfsem, 0, 1); in pipecommon_allocdev()
156 sem_init(&dev->d_rdsem, 0, 0); in pipecommon_allocdev()
[all …]
/third_party/uboot/u-boot-2020.01/include/dm/
Dread.h19 static inline const struct device_node *dev_np(struct udevice *dev) in dev_np() argument
21 return ofnode_to_np(dev->node); in dev_np()
24 static inline const struct device_node *dev_np(struct udevice *dev) in dev_np() argument
36 static inline ofnode dev_ofnode(struct udevice *dev) in dev_ofnode() argument
38 return dev->node; in dev_ofnode()
41 static inline bool dev_of_valid(struct udevice *dev) in dev_of_valid() argument
43 return ofnode_valid(dev_ofnode(dev)); in dev_of_valid()
56 int dev_read_u32(struct udevice *dev, const char *propname, u32 *outp);
66 int dev_read_u32_default(struct udevice *dev, const char *propname, int def);
76 int dev_read_s32(struct udevice *dev, const char *propname, s32 *outp);
[all …]
/third_party/uboot/u-boot-2020.01/drivers/core/
Ddevice.c39 struct udevice *dev; in device_bind_common() local
54 dev = calloc(1, sizeof(struct udevice)); in device_bind_common()
55 if (!dev) in device_bind_common()
58 INIT_LIST_HEAD(&dev->sibling_node); in device_bind_common()
59 INIT_LIST_HEAD(&dev->child_head); in device_bind_common()
60 INIT_LIST_HEAD(&dev->uclass_node); in device_bind_common()
62 INIT_LIST_HEAD(&dev->devres_head); in device_bind_common()
64 dev->platdata = platdata; in device_bind_common()
65 dev->driver_data = driver_data; in device_bind_common()
66 dev->name = name; in device_bind_common()
[all …]
Dread.c14 int dev_read_u32(struct udevice *dev, const char *propname, u32 *outp) in dev_read_u32() argument
16 return ofnode_read_u32(dev_ofnode(dev), propname, outp); in dev_read_u32()
19 int dev_read_u32_default(struct udevice *dev, const char *propname, int def) in dev_read_u32_default() argument
21 return ofnode_read_u32_default(dev_ofnode(dev), propname, def); in dev_read_u32_default()
24 int dev_read_s32(struct udevice *dev, const char *propname, s32 *outp) in dev_read_s32() argument
26 return ofnode_read_u32(dev_ofnode(dev), propname, (u32 *)outp); in dev_read_s32()
29 int dev_read_s32_default(struct udevice *dev, const char *propname, int def) in dev_read_s32_default() argument
31 return ofnode_read_u32_default(dev_ofnode(dev), propname, def); in dev_read_s32_default()
34 int dev_read_u32u(struct udevice *dev, const char *propname, uint *outp) in dev_read_u32u() argument
39 ret = ofnode_read_u32(dev_ofnode(dev), propname, &val); in dev_read_u32u()
[all …]
Ddevice-remove.c21 int device_chld_unbind(struct udevice *dev, struct driver *drv) in device_chld_unbind() argument
26 assert(dev); in device_chld_unbind()
28 list_for_each_entry_safe(pos, n, &dev->child_head, sibling_node) { in device_chld_unbind()
40 int device_chld_remove(struct udevice *dev, struct driver *drv, in device_chld_remove() argument
46 assert(dev); in device_chld_remove()
48 list_for_each_entry_safe(pos, n, &dev->child_head, sibling_node) { in device_chld_remove()
60 int device_unbind(struct udevice *dev) in device_unbind() argument
65 if (!dev) in device_unbind()
68 if (dev->flags & DM_FLAG_ACTIVATED) in device_unbind()
71 if (!(dev->flags & DM_FLAG_BOUND)) in device_unbind()
[all …]
/third_party/uboot/u-boot-2020.01/drivers/net/
Dlan91c96.c116 static int smc_get_ethaddr(bd_t *bd, struct eth_device *dev);
117 static int get_rom_mac(struct eth_device *dev, unsigned char *v_rom_mac);
143 void dump_memory_info(struct eth_device *dev) in dump_memory_info() argument
148 old_bank = SMC_inw(dev, LAN91C96_BANK_SELECT) & 0xF; in dump_memory_info()
150 SMC_SELECT_BANK(dev, 0); in dump_memory_info()
151 mem_info = SMC_inw(dev, LAN91C96_MIR); in dump_memory_info()
154 SMC_SELECT_BANK(dev, old_bank); in dump_memory_info()
164 static int poll4int (struct eth_device *dev, byte mask, int timeout) in poll4int() argument
168 word old_bank = SMC_inw(dev, LAN91C96_BANK_SELECT); in poll4int()
171 SMC_SELECT_BANK(dev, 2); in poll4int()
[all …]
Dks8851_mll.c105 static u8 ks_rdreg8(struct eth_device *dev, u16 offset) in ks_rdreg8() argument
110 writew(offset | (BE0 << shift_bit), dev->iobase + 2); in ks_rdreg8()
112 return (u8)(readw(dev->iobase) >> shift_data); in ks_rdreg8()
115 static u16 ks_rdreg16(struct eth_device *dev, u16 offset) in ks_rdreg16() argument
117 writew(offset | ((BE1 | BE0) << (offset & 0x02)), dev->iobase + 2); in ks_rdreg16()
119 return readw(dev->iobase); in ks_rdreg16()
122 static void ks_wrreg8(struct eth_device *dev, u16 offset, u8 val) in ks_wrreg8() argument
127 writew(offset | (BE0 << shift_bit), dev->iobase + 2); in ks_wrreg8()
128 writew(value_write, dev->iobase); in ks_wrreg8()
131 static void ks_wrreg16(struct eth_device *dev, u16 offset, u16 val) in ks_wrreg16() argument
[all …]
Dax88180.c52 static void ax88180_rx_handler (struct eth_device *dev);
53 static int ax88180_phy_initial (struct eth_device *dev);
54 static void ax88180_media_config (struct eth_device *dev);
55 static unsigned long get_CicadaPHY_media_mode (struct eth_device *dev);
56 static unsigned long get_MarvellPHY_media_mode (struct eth_device *dev);
57 static unsigned short ax88180_mdio_read (struct eth_device *dev,
59 static void ax88180_mdio_write (struct eth_device *dev,
67 static int ax88180_mdio_check_complete (struct eth_device *dev) in ax88180_mdio_check_complete() argument
74 tmpval = INW (dev, MDIOCTRL); in ax88180_mdio_check_complete()
83 ax88180_mdio_read (struct eth_device *dev, unsigned long regaddr) in ax88180_mdio_read() argument
[all …]
Dsmc911x.c16 u32 pkt_data_pull(struct eth_device *dev, u32 addr) \
18 void pkt_data_push(struct eth_device *dev, u32 addr, u32 val) \
21 static void smc911x_handle_mac_address(struct eth_device *dev) in smc911x_handle_mac_address() argument
24 uchar *m = dev->enetaddr; in smc911x_handle_mac_address()
28 smc911x_set_mac_csr(dev, ADDRL, addrl); in smc911x_handle_mac_address()
29 smc911x_set_mac_csr(dev, ADDRH, addrh); in smc911x_handle_mac_address()
34 static int smc911x_eth_phy_read(struct eth_device *dev, in smc911x_eth_phy_read() argument
37 while (smc911x_get_mac_csr(dev, MII_ACC) & MII_ACC_MII_BUSY) in smc911x_eth_phy_read()
40 smc911x_set_mac_csr(dev, MII_ACC, phy << 11 | reg << 6 | in smc911x_eth_phy_read()
43 while (smc911x_get_mac_csr(dev, MII_ACC) & MII_ACC_MII_BUSY) in smc911x_eth_phy_read()
[all …]
Dcs8900.c50 static u16 get_reg_init_bus(struct eth_device *dev, int regno) in get_reg_init_bus() argument
53 struct cs8900_priv *priv = (struct cs8900_priv *)(dev->priv); in get_reg_init_bus()
54 uint8_t volatile * const iob = (uint8_t volatile * const)dev->iobase; in get_reg_init_bus()
67 static u16 get_reg(struct eth_device *dev, int regno) in get_reg() argument
69 struct cs8900_priv *priv = (struct cs8900_priv *)(dev->priv); in get_reg()
75 static void put_reg(struct eth_device *dev, int regno, u16 val) in put_reg() argument
77 struct cs8900_priv *priv = (struct cs8900_priv *)(dev->priv); in put_reg()
82 static void cs8900_reset(struct eth_device *dev) in cs8900_reset() argument
88 put_reg(dev, PP_SelfCTL, get_reg(dev, PP_SelfCTL) | PP_SelfCTL_Reset); in cs8900_reset()
95 while ((((us = get_reg_init_bus(dev, PP_SelfSTAT)) & in cs8900_reset()
[all …]
/third_party/uboot/u-boot-2020.01/cmd/
Dtpm_test.c31 static uint32_t TlclStartupIfNeeded(struct udevice *dev) in TlclStartupIfNeeded() argument
33 uint32_t result = tpm_startup(dev, TPM_ST_CLEAR); in TlclStartupIfNeeded()
38 static int test_timer(struct udevice *dev) in test_timer() argument
44 static uint32_t tpm_get_flags(struct udevice *dev, uint8_t *disable, in tpm_get_flags() argument
50 result = tpm_get_permanent_flags(dev, &pflags); in tpm_get_flags()
65 static uint32_t tpm_nv_write_value_lock(struct udevice *dev, uint32_t index) in tpm_nv_write_value_lock() argument
69 return tpm_nv_write_value(dev, index, NULL, 0); in tpm_nv_write_value_lock()
72 static int tpm_is_owned(struct udevice *dev) in tpm_is_owned() argument
77 result = tpm_read_pubek(dev, response, sizeof(response)); in tpm_is_owned()
82 static int test_early_extend(struct udevice *dev) in test_early_extend() argument
[all …]
/third_party/wpa_supplicant/wpa_supplicant-2.9/src/wps/
Dwps_dev_attr.c16 int wps_build_manufacturer(struct wps_device_data *dev, struct wpabuf *msg) in wps_build_manufacturer() argument
21 len = dev->manufacturer ? os_strlen(dev->manufacturer) : 0; in wps_build_manufacturer()
35 wpabuf_put_data(msg, dev->manufacturer, len); in wps_build_manufacturer()
40 int wps_build_model_name(struct wps_device_data *dev, struct wpabuf *msg) in wps_build_model_name() argument
45 len = dev->model_name ? os_strlen(dev->model_name) : 0; in wps_build_model_name()
59 wpabuf_put_data(msg, dev->model_name, len); in wps_build_model_name()
64 int wps_build_model_number(struct wps_device_data *dev, struct wpabuf *msg) in wps_build_model_number() argument
69 len = dev->model_number ? os_strlen(dev->model_number) : 0; in wps_build_model_number()
83 wpabuf_put_data(msg, dev->model_number, len); in wps_build_model_number()
88 int wps_build_serial_number(struct wps_device_data *dev, struct wpabuf *msg) in wps_build_serial_number() argument
[all …]
/third_party/wpa_supplicant/wpa_supplicant-2.9_standard/src/wps/
Dwps_dev_attr.c16 int wps_build_manufacturer(struct wps_device_data *dev, struct wpabuf *msg) in wps_build_manufacturer() argument
21 len = dev->manufacturer ? os_strlen(dev->manufacturer) : 0; in wps_build_manufacturer()
35 wpabuf_put_data(msg, dev->manufacturer, len); in wps_build_manufacturer()
40 int wps_build_model_name(struct wps_device_data *dev, struct wpabuf *msg) in wps_build_model_name() argument
45 len = dev->model_name ? os_strlen(dev->model_name) : 0; in wps_build_model_name()
59 wpabuf_put_data(msg, dev->model_name, len); in wps_build_model_name()
64 int wps_build_model_number(struct wps_device_data *dev, struct wpabuf *msg) in wps_build_model_number() argument
69 len = dev->model_number ? os_strlen(dev->model_number) : 0; in wps_build_model_number()
83 wpabuf_put_data(msg, dev->model_number, len); in wps_build_model_number()
88 int wps_build_serial_number(struct wps_device_data *dev, struct wpabuf *msg) in wps_build_serial_number() argument
[all …]
/third_party/uboot/u-boot-2020.01/drivers/power/regulator/
Dregulator-uclass.c14 int regulator_mode(struct udevice *dev, struct dm_regulator_mode **modep) in regulator_mode() argument
20 uc_pdata = dev_get_uclass_platdata(dev); in regulator_mode()
28 int regulator_get_value(struct udevice *dev) in regulator_get_value() argument
30 const struct dm_regulator_ops *ops = dev_get_driver_ops(dev); in regulator_get_value()
35 return ops->get_value(dev); in regulator_get_value()
38 static void regulator_set_value_ramp_delay(struct udevice *dev, int old_uV, in regulator_set_value_ramp_delay() argument
43 debug("regulator %s: delay %u us (%d uV -> %d uV)\n", dev->name, delay, in regulator_set_value_ramp_delay()
49 int regulator_set_value(struct udevice *dev, int uV) in regulator_set_value() argument
51 const struct dm_regulator_ops *ops = dev_get_driver_ops(dev); in regulator_set_value()
55 uc_pdata = dev_get_uclass_platdata(dev); in regulator_set_value()
[all …]
/third_party/uboot/u-boot-2020.01/product/hiosd/vo/mkp/src/dev/
Dmkp_vo_dev.c33 hi_u32 vo_dev_get_bg_color(hi_vo_dev dev) in vo_dev_get_bg_color() argument
35 return g_bg_color[dev]; in vo_dev_get_bg_color()
38 hi_void vo_dev_set_bg_color(hi_vo_dev dev, hi_u32 bg_color) in vo_dev_set_bg_color() argument
40 g_bg_color[dev] = bg_color; in vo_dev_set_bg_color()
51 hi_s32 vo_init_dev_ctx(hi_vo_dev dev) in vo_init_dev_ctx() argument
56 dev_ctx = vo_get_dev_ctx(dev); in vo_init_dev_ctx()
75 hi_bool vo_is_dev_enabled(hi_vo_dev dev) in vo_is_dev_enabled() argument
79 if (vo_def_check_dev_id(dev) != HI_SUCCESS) { in vo_is_dev_enabled()
80 vo_warn_trace("Vo device id %d is invalid!\n", dev); in vo_is_dev_enabled()
84 dev_ctx = vo_get_dev_ctx(dev); in vo_is_dev_enabled()
[all …]
/third_party/NuttX/drivers/usbdev/gadget/fconfig/src/
Df_generic.c59 static int usbclass_generic_bind(struct usbdevclass_driver_s *driver, struct usbdev_s *dev);
60 static int usbclass_generic_unbind(struct usbdevclass_driver_s *driver, struct usbdev_s *dev);
61 static int usbclass_generic_setup(struct usbdevclass_driver_s *driver, struct usbdev_s *dev,
64 static void usbclass_generic_disconnect(struct usbdevclass_driver_s *driver, struct usbdev_s *dev);
143 static void generic_discard_events(struct generic_dev_s *dev, in generic_discard_events() argument
148 uint32_t ev = dev->efifo.out, out = ev; in generic_discard_events()
151 for (; ev < dev->efifo.in; ++ev) in generic_discard_events()
153 if ((dev->efifo.data[ev & mask] == type1 || in generic_discard_events()
154 dev->efifo.data[ev & mask] == type2) == keep) in generic_discard_events()
156 dev->efifo.data[out++ & mask] = dev->efifo.data[ev & mask]; in generic_discard_events()
[all …]
/third_party/uboot/u-boot-2020.01/test/dm/
Dbus.c33 static int testbus_drv_probe(struct udevice *dev) in testbus_drv_probe() argument
35 return dm_scan_fdt_dev(dev); in testbus_drv_probe()
38 static int testbus_child_post_bind(struct udevice *dev) in testbus_child_post_bind() argument
42 plat = dev_get_parent_platdata(dev); in testbus_child_post_bind()
49 static int testbus_child_pre_probe(struct udevice *dev) in testbus_child_pre_probe() argument
51 struct dm_test_parent_data *parent_data = dev_get_parent_priv(dev); in testbus_child_pre_probe()
58 static int testbus_child_pre_probe_uclass(struct udevice *dev) in testbus_child_pre_probe_uclass() argument
60 struct dm_test_priv *priv = dev_get_priv(dev); in testbus_child_pre_probe_uclass()
67 static int testbus_child_post_probe_uclass(struct udevice *dev) in testbus_child_post_probe_uclass() argument
69 struct dm_test_priv *priv = dev_get_priv(dev); in testbus_child_post_probe_uclass()
[all …]
/third_party/libdrm/amdgpu/
Damdgpu_device.c96 static void amdgpu_device_free_internal(amdgpu_device_handle dev) in amdgpu_device_free_internal() argument
101 while (*node != dev && (*node)->next) in amdgpu_device_free_internal()
106 close(dev->fd); in amdgpu_device_free_internal()
107 if ((dev->flink_fd >= 0) && (dev->fd != dev->flink_fd)) in amdgpu_device_free_internal()
108 close(dev->flink_fd); in amdgpu_device_free_internal()
110 amdgpu_vamgr_deinit(&dev->vamgr_32); in amdgpu_device_free_internal()
111 amdgpu_vamgr_deinit(&dev->vamgr); in amdgpu_device_free_internal()
112 amdgpu_vamgr_deinit(&dev->vamgr_high_32); in amdgpu_device_free_internal()
113 amdgpu_vamgr_deinit(&dev->vamgr_high); in amdgpu_device_free_internal()
114 handle_table_fini(&dev->bo_handles); in amdgpu_device_free_internal()
[all …]
/third_party/uboot/u-boot-2020.01/common/
Dusb.c59 struct usb_device *dev; in usb_init() local
96 ret = usb_alloc_new_device(ctrl, &dev); in usb_init()
104 ret = usb_new_device(dev); in usb_init()
106 usb_free_device(dev->controller); in usb_init()
201 int usb_int_msg(struct usb_device *dev, unsigned long pipe, in usb_int_msg() argument
204 return submit_int_msg(dev, pipe, buffer, transfer_len, interval, in usb_int_msg()
217 int usb_control_msg(struct usb_device *dev, unsigned int pipe, in usb_control_msg() argument
241 dev->status = USB_ST_NOT_PROC; /*not yet processed */ in usb_control_msg()
243 err = submit_control_msg(dev, pipe, data, size, setup_packet); in usb_control_msg()
255 if (!((volatile unsigned long)dev->status & USB_ST_NOT_PROC)) in usb_control_msg()
[all …]

12345678910>>...223